ES6&數(shù)組擴展

ES6數(shù)組擴展

1.Array.from()

定義:Array.from()用于將兩類對象轉(zhuǎn)換成真正的數(shù)組:類數(shù)組對象和可遍歷的對象(具有Iterator接口)

1.類似數(shù)組對象

示例
var some = {
"0" : "hello",
"1" : "world",
"2" : "lijaha",
"length" : "3"
}
使用Array.from()方法轉(zhuǎn)換成數(shù)組
var array = Array.from(some);

應(yīng)用中常見的類似數(shù)組對象有:DOM操作返回的NodeList集合以及函數(shù)內(nèi)部的arguments

示例
1.NodeList集合
var list = Array.from(document.querySelectorAll('p'));
list.forEach((element) => console.log(element)); //只有數(shù)組才能使用forEach方法進行遍歷
2.函數(shù)內(nèi)部的arguments
function count() {
var arg = Array.from(arguments);
}

2.可遍歷對象

示例
var sring = 'hello';
var array = Array.from(string); //Array.from('hello')

ES6新增數(shù)據(jù)結(jié)構(gòu)Map和Set
//Set數(shù)據(jù)結(jié)構(gòu)
var someSet = new Set(['a', 'b', 'c']);
var array = Array.from(someSet);
//Map數(shù)據(jù)結(jié)構(gòu)
var someMap = new Map([['name', 'lijaha'],['age', '20']);
var array = Array.from(someMap) //會轉(zhuǎn)化成二維數(shù)組

此外螟碎,擴展運算符(...)也可以將具有遍歷器接口(Iterator)的數(shù)據(jù)結(jié)構(gòu)轉(zhuǎn)換成數(shù)組

示例
function count() {
var arg = [...arguments];
}

var liat = [...document.querySelectorAll('p')];

所謂類數(shù)組的對象眉菱,本質(zhì)都是擁有l(wèi)ength屬性,任何擁有l(wèi)ength屬性的對象都可以通過Array.from()轉(zhuǎn)換成數(shù)組
Array.from()的第二參數(shù)類似于數(shù)組中的map方法掉分,用來對數(shù)組中的每個元素進行操作俭缓,并返回操作結(jié)果后的新數(shù)組。

示例
var array = [1,2,3];
array.map((x) => x2); //ES5數(shù)組map方法酥郭,map擁有三個參數(shù)华坦,element、index不从、array
Array.from(array,(x) => x
2);

2.Array.of()

定義:將一組值轉(zhuǎn)化成數(shù)組

//Array.of主要是用來彌補new Array()構(gòu)造函數(shù)傳參的不足
var array = new Array(); //new一個空組[]
var array = new Array(2); //new一個length為2的數(shù)組[ , ]
var array = new Array(1,2,3); //new一個[1,2,3]數(shù)組
由上面可以看出new Array()根據(jù)傳參個數(shù)的不同而導(dǎo)致不同的重載

Array.of()示例
var array = Array.of(); //new一個空數(shù)組
var array = Array.of(2); //[2]
var array = Array.of(1,2,3); //[1,2,3]

3.數(shù)組實例find()和findIndex()

定義:find方法用來找出數(shù)組中第一個符合條件的數(shù)組成員惜姐,findIndex方法用來找出數(shù)組中第一個符合條件的數(shù)組成員的下標

示例
var array = Array.of(1,2,3,4);
array.find((element) => element > 1); //2
array.findIndex((element) => element == 2); //1
可借助Object.is方法來識別NaN,用來彌補indexOf()方法的不足,indexOf內(nèi)部使用‘===’來判斷椿息,因為NaN是一個不確定的數(shù)歹袁,NaN === NaN(false)
[NaN].indexOf(NaN); //-1
[NaN].findIndex((element) => Object.is(NaN,element)); //

4.數(shù)組實例entries()、keys()和values()

定義:用來遍歷數(shù)組寝优,entries()是對鍵值的遍歷宇攻、keys()是對鍵的遍歷、values()是對值得遍歷

示例
var array = Array.of(2,3,4);
//使用entries()方法
for (let [index,element] of array.entries()){
console.log(index,element);
}
//使用keys()方法
for (let key of array.keys()){
console.log(key);
}
//使用values()方法
for (ler value of array.values()){
console.log(value);
}

5.數(shù)組實例Array.includes()

ES7方法倡勇,Array.includes()方法返回一個布爾值逞刷,表示數(shù)組是否含有給定的值

示例
var array = [2,3,4];
array.includes(3); //true
array.includes(5); //false
使用includes()可避免對indexOf()方法對NaN的誤判
[NaN].includes(NaN); //true

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末嘉涌,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子夸浅,更是在濱河造成了極大的恐慌仑最,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件帆喇,死亡現(xiàn)場離奇詭異警医,居然都是意外死亡,警方通過查閱死者的電腦和手機坯钦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門预皇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人婉刀,你說我怎么就攤上這事吟温。” “怎么了突颊?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵鲁豪,是天一觀的道長。 經(jīng)常有香客問我律秃,道長爬橡,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任棒动,我火速辦了婚禮糙申,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘船惨。我一直安慰自己柜裸,他們只是感情好,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布掷漱。 她就那樣靜靜地躺著粘室,像睡著了一般榄檬。 火紅的嫁衣襯著肌膚如雪卜范。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天鹿榜,我揣著相機與錄音海雪,去河邊找鬼。 笑死舱殿,一個胖子當著我的面吹牛奥裸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播沪袭,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼湾宙,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起侠鳄,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤埠啃,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后伟恶,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體碴开,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年博秫,在試婚紗的時候發(fā)現(xiàn)自己被綠了潦牛。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡挡育,死狀恐怖巴碗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情静盅,我是刑警寧澤良价,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站蒿叠,受9級特大地震影響明垢,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜市咽,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一痊银、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧施绎,春花似錦溯革、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至俱尼,卻和暖如春抖单,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背遇八。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工矛绘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人刃永。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓货矮,卻偏偏與公主長得像,于是被迫代替她去往敵國和親斯够。 傳聞我的和親對象是個殘疾皇子囚玫,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容

  • [JavaScript數(shù)組]一篇中介紹了ES6之前的數(shù)組方法喧锦。本篇介紹一下ES6里新增的數(shù)組方法。 keys抓督,va...
    sponing閱讀 299評論 0 0
  • 1. Array.from() Array.from方法用于將兩類對象轉(zhuǎn)為真正的數(shù)組:類似數(shù)組的對象(array-...
    前端小華子閱讀 291評論 0 1
  • //Array.of 可以生成一個簡單數(shù)組裸违, { let arr = Array.of(3,4,7,9,1...
    super靜_jingjing閱讀 296評論 0 1
  • 1.Array.of() Array.of() 方法創(chuàng)建一個具有可變數(shù)量參數(shù)的新數(shù)組實例,而不考慮參數(shù)的數(shù)量或類型...
    bjhu電net閱讀 232評論 0 0
  • 我覺得這個問題是想問,做一件事如何讓自己獲得內(nèi)在驅(qū)動力和外在驅(qū)動力涌穆? 原因有四個怔昨,第一,沒有正確的認知宿稀。第二趁舀,沒有...
    厭生平閱讀 613評論 2 1