亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

ES6基礎之數組和對象的拓展實例詳解

2019-11-19 10:59:45
字體:
來源:轉載
供稿:網友

本文實例講述了ES6基礎之數組和對象的拓展。分享給大家供大家參考,具體如下:

數組的擴展

1.拓展運算符('...'),它相當于rest參數的逆運算,用于將一個數組轉換為用逗號分隔的參數序列;

console.log(...[1, 2, 3])// 1 2 3console.log(1, ...[2, 3, 4], 5)// 1 2 3 4 5

2.如果擴展運算符后面是一個空數組,則不產生任何效果;

[...[], 1]// [1]

3.常見的拓展運算符的應用:

//合并數組let arr1 = [1,2];let arr2 = [3,4];let arr3 = [5,6];let newArr = [...arr1 , ...arr2 , ...arr3]; //等同于ES5 [].concat( arr1 , arr2 , arr3 )// [1,2,3,4,5,6]//與解構賦值結合(用于生成數組)const [ val , ...rest] = [1, 2, 3, 4, 5];val // 1rest // [2, 3, 4, 5]//將字符串轉為真正的數組let str = 'mine';[...str] // ["m","i","n","e"]//可以將類數組轉化成正真的數組 let arrayLike = {  0 : 'div.class1' ,  1 : 'div.class2' ,  2 : 'div.class3' ,  length : 3}console.log([...arrayLike]) // ["div.class1","div.class2","div.class3"]

4.新增 Array.from 方法,可以將類似數組的對象(array-like object)和可遍歷(iterable)的對象轉化成真正的數組;該方法還可以接受第二個參數,作用類似于數組的map方法,用來對每個元素進行處理,將處理后的值放入返回的數組;

let arr = [ 1 , 2 , 3];arr.map( x => x * x);// [ 1 , 4 , 9 ]Array.from(arr, (x) => x * x)// [ 1 , 4 , 9 ]

5.新增 Array.of 方法 ,用于將一組值,轉換為數組(該方法基本上可以用來替代Array()new Array(),避免出現參數不同而導致的重載);

//傳統ArrayArray() // []Array(3) // [, , ,]Array(1, 2, 3) // [1, 2, 3]//Array.ofArray.of() // []Array.of(undefined) // [undefined]Array.of(1) // [1]Array.of(1, 2) // [1, 2]

6.數組實例方法 find() 用于找出第一個符合條件的數組成員,該方法的參數是一個回調函數,該回調函數可以接收三個參數,依次是當前元素,當前元素索引,數組本身;如果查找成功,返回符合條件的第一個成員,如果沒有符合條件的成員,則返回undefined;

var arr = [1, 2, 4, 5];var r = arr.find(function( element , index , self ){  return element % 2 == 0;})r // 2

7.數組實例方法 findIndex() , 該方法的參數與 find() 一樣 , 不同的是該方法 返回的是第一個符合條件的數組成員的位置,如果所有成員都不符合條件,則返回-1;

var arr = [1, 2, 4, 5];var r = arr.find(function( element , index , self ){  return element % 2 == 0;})r // 1

ps:find() 和 findIndex() 這兩個方法都可以發現NaN,彌補了數組的IndexOf方法的不足。

8.數組實例方法 includes() , 方法返回一個布爾值,表示某個數組是否包含給定的值,與字符串的includes方法類似;該方法接收兩個參數,第一個參數是要查找的成員,第二個參數表示搜索的起始位置(如果為負數,則表示倒數的位置,如果大于數組長度,則會重置為從0開始)

[1, 2, 3].includes(2)   // true[1, 2, 3].includes(4)   // false[1, 2, 3].includes(3, 3); // false[1, 2, 3].includes(3, -1); // true

對象的拓展

1.ES6 允許直接寫入變量和函數,作為對象的屬性和方法(在對象中,直接寫變量時,屬性名為變量名, 屬性值為變量的值)

//屬性簡寫var foo = 'bar';var obj = {foo};obj // { foo : "bar" }//變量簡寫var mine = {  foo ,  method(){    //to do  }}

2.ES6 允許字面量定義對象時,用表達式作為對象的屬性名或者方法名,即把表達式放在方括號內;

let propKey = 'foo';let obj = { [propKey]: true, ['a' + 'bc']: 123, ['s' + 'ay'](){  console.log('hello world') }}obj // {"foo":true,"abc":123}obj.say() // 'hello world'

3.新增 Object.is() 方法,用來比較兩個值是否嚴格相等,與嚴格比較運算符(===)的行為基本一致,不同之處在于一是+0不等于-0,二是NaN等于自身。

+0 === -0 //trueNaN === NaN // falseObject.is(+0, -0) // falseObject.is(NaN, NaN) // true

4.新增 Object.assign 方法用于對象的合并,將源對象(source)的所有可枚舉屬性,復制到目標對象(target),第一個參數是目標對象,后面的參數都是源對象;

var target = { a: 1 };var source1 = { b: 2 };var source2 = { c: 3 };Object.assign(target, source1, source2);target // {a:1, b:2, c:3}

ps:如果目標對象與源對象有同名屬性,或多個源對象有同名屬性,則后面的屬性會覆蓋前面的屬性。

var target = { a: 1, b: 1 };var source1 = { b: 2, c: 2 };var source2 = { c: 3 };Object.assign(target, source1, source2);target // {a:1, b:2, c:3}

該方法不能用于目標對象是 undefined 和 null 上, 會報錯;

5.Object.assign 方法實行的是淺拷貝,而不是深拷貝。如果源對象某個屬性的值是對象,那么目標對象拷貝得到的是這個對象的引用,修改會對原對象造成影響;

var obj1 = {a: {b: 1}};var obj2 = Object.assign({}, obj1);obj1.a.b = 2;obj2.a.b   // 2

6.Object.assign 方法常用于以下幾個方面

為對象添加屬性

var _this = {};Object.assign( _this , { name : 'mine' } );_this // { name : 'mine' }

為對象添加方法

var _this = {};Object.assign( _this , { func(){ console.log('hello world') } } );_this.func() // hello world

克隆對象

var _this = { name : 'mine' };Object.assign( {} , _this );

合并多個對象

var _this = {};var source1 = { name : 'mine' };var source2 = { mail : 'your' };Object.assign( _this , source1 , source2 );_this // {"name":"mine","mail":"your"}

為屬性指定默認值

var default = { name : 'mine' , mail : 'your' }function processContent(options) {options = Object.assign({}, default , options);// to do}

7.Object.setPrototypeOf方法的作用與_proto_相同,用來設置一個對象的prototype對象,返回參數對象本身。它是 ES6 正式推薦的設置原型對象的方法。

let proto = {};let obj = { x: 10 };Object.setPrototypeOf(obj, proto);proto.y = 20;proto.z = 40;obj.x // 10obj.y // 20obj.z // 40

8.Object.getPrototypeOf()方法,該方法與Object.setPrototypeOf方法配套,用于讀取一個對象的原型對象。

9.Object.keys(),Object.values(),Object.entries() 除第一個外,后面兩個是ES6新增的方法,用于遍歷對象,返回都是數組,成員是參數對象自身的(不含繼承的)所有可遍歷(enumerable)屬性的鍵、值和鍵值對數組。

let obj = { a : 1 , b : 'hello' }Object.keys( obj );   // ["a","b"]Object.values( obj );  // [1,"hello"]Object.entries( obj ); // [["a",1],["b","hello"]]

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.VeVB.COm/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品久久久久中文字幕欢迎你| 日韩亚洲一区二区| 欧美www在线| 精品久久久久国产| 国产亚洲精品久久久久久777| 日韩激情视频在线播放| 亚洲加勒比久久88色综合| 久久乐国产精品| 中文字幕亚洲欧美在线| 中文字幕欧美日韩| 色综久久综合桃花网| 奇米一区二区三区四区久久| 最新69国产成人精品视频免费| 国产精品视频免费在线观看| 另类天堂视频在线观看| 在线色欧美三级视频| 久久久久久久97| 国产免费观看久久黄| 久久综合九色九九| 午夜精品一区二区三区在线视频| 精品久久久一区二区| 国产成人亚洲综合91| 日韩免费av片在线观看| 久久久久久久亚洲精品| 色偷偷av一区二区三区乱| 国产欧美一区二区三区在线| 欧美午夜久久久| 日韩电影在线观看永久视频免费网站| 国产精品福利久久久| 国产伦精品一区二区三区精品视频| 日韩免费av片在线观看| 69久久夜色精品国产69| 日韩电影中文字幕在线| 91精品国产91久久久久久不卡| 亚洲精品永久免费| 国产一区二区黄| 日韩av片永久免费网站| 茄子视频成人在线| 国产精品一香蕉国产线看观看| 精品久久久一区| 成人网在线免费看| 国产成人精品电影久久久| 欧美激情videos| 亚洲欧美国产视频| 全色精品综合影院| 亚洲毛片在线观看.| 欧美一级视频免费在线观看| 欧美重口另类videos人妖| 久久精品最新地址| 日本a级片电影一区二区| 日本高清久久天堂| 日韩av中文字幕在线免费观看| 国产精品亚洲综合天堂夜夜| 久久久久久久香蕉网| 亚洲欧洲日产国码av系列天堂| 韩国三级电影久久久久久| 亚洲精品免费在线视频| 91网站在线看| 亚洲一区二区自拍| 欧美有码在线观看| 国产一区二区三区在线看| 亚洲国产精品久久久久秋霞不卡| 欧美丰满少妇xxxx| 亚洲精品一区二区三区婷婷月| 欧美日韩视频免费播放| 欧洲成人午夜免费大片| 亚洲国产精品久久| 日韩久久精品成人| 激情成人中文字幕| 亚洲欧美精品中文字幕在线| 68精品国产免费久久久久久婷婷| 欧美视频在线免费看| 亚洲综合国产精品| 欧美日韩综合视频网址| 欧美精品成人在线| 精品中文字幕视频| 亚洲高清av在线| 美女国内精品自产拍在线播放| 亚洲午夜精品久久久久久性色| 欧美激情精品久久久久| 国产精品视频男人的天堂| 久久国产精彩视频| 亚洲激情国产精品| 国产精品中文在线| 国产欧美一区二区| 国产精品大陆在线观看| 午夜精品久久久久久久男人的天堂| 2024亚洲男人天堂| 亚洲色图美腿丝袜| 91av在线网站| 亚洲全黄一级网站| 亚洲综合成人婷婷小说| 久久躁日日躁aaaaxxxx| 日韩成人小视频| 91精品国产91久久久久福利| 欧美色道久久88综合亚洲精品| 91天堂在线视频| 欧美午夜激情小视频| 96精品视频在线| 欧美日韩福利视频| 亚洲欧美日韩一区在线| 久久亚洲春色中文字幕| 97超视频免费观看| 日韩在线视频二区| 欧美黄色www| 国内成人精品一区| 91爱爱小视频k| 国产精品高精视频免费| 欧美午夜视频在线观看| 国产精品久久久久久久av电影| 久久久91精品国产一区不卡| 久久久久久久久久国产| 久久天天躁狠狠躁老女人| 成人疯狂猛交xxx| 国产精品久久久999| 国产丝袜高跟一区| 色综合久久天天综线观看| 亚洲欧洲国产伦综合| 久久久久久久久网站| 亚洲欧美日韩天堂一区二区| 亚洲天堂av综合网| 日韩精品有码在线观看| 午夜精品一区二区三区在线视| 亚洲人成在线免费观看| 久久久久久久影视| 亚洲日韩第一页| 永久免费看mv网站入口亚洲| 2019中文字幕全在线观看| 亚洲性猛交xxxxwww| 久久亚洲一区二区三区四区五区高| 久热精品视频在线免费观看| 日本久久91av| 日韩精品福利网站| 亚洲一区二区三区视频| 日韩av在线免费观看一区| 欧美激情精品久久久久久大尺度| 欧美激情xxxxx| 亚洲午夜小视频| 日韩精品亚洲视频| 懂色av中文一区二区三区天美| 97精品视频在线播放| 亚洲自拍偷拍区| 欧美亚洲视频在线看网址| 欧美黑人性猛交| 国产精自产拍久久久久久| 亚洲精品99久久久久| 欧美性xxxx极品hd欧美风情| 精品国产自在精品国产浪潮| 日韩在线视频二区| 98精品在线视频| 中文字幕精品影院| 亚洲va久久久噜噜噜| 成人午夜黄色影院| 日韩中文av在线| 亚洲毛片在线免费观看| 久久国产色av| 91亚洲国产成人精品性色| 国产精品视频99| 成人午夜黄色影院| 欧美激情综合色综合啪啪五月| 日韩有码片在线观看| 国产一区二区三区三区在线观看| 欧美一区二区三区免费视| 精品亚洲aⅴ在线观看|