ES6&數組擴展

ES6數組擴展

1.Array.from()

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

1.類似數組對象

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

應用中常見的類似數組對象有:DOM操作返回的NodeList集合以及函數內部的arguments

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

2.可遍歷對象

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

ES6新增數據結構Map和Set
//Set數據結構
var someSet = new Set(['a', 'b', 'c']);
var array = Array.from(someSet);
//Map數據結構
var someMap = new Map([['name', 'lijaha'],['age', '20']);
var array = Array.from(someMap) //會轉化成二維數組

此外,擴展運算符(...)也可以將具有遍歷器接口(Iterator)的數據結構轉換成數組

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

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

所謂類數組的對象,本質都是擁有length屬性,任何擁有length屬性的對象都可以通過Array.from()轉換成數組
Array.from()的第二參數類似于數組中的map方法,用來對數組中的每個元素進行操作,并返回操作結果后的新數組。

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

2.Array.of()

定義:將一組值轉化成數組

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

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

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

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

示例
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內部使用‘===’來判斷,因為NaN是一個不確定的數,NaN === NaN(false)
[NaN].indexOf(NaN); //-1
[NaN].findIndex((element) => Object.is(NaN,element)); //

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

定義:用來遍歷數組,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.數組實例Array.includes()

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

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

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • [JavaScript數組]一篇中介紹了ES6之前的數組方法。本篇介紹一下ES6里新增的數組方法。 keys,va...
    sponing閱讀 310評論 0 0
  • 1. Array.from() Array.from方法用于將兩類對象轉為真正的數組:類似數組的對象(array-...
    前端小華子閱讀 297評論 0 1
  • //Array.of 可以生成一個簡單數組, { let arr = Array.of(3,4,7,9,1...
    super靜_jingjing閱讀 307評論 0 1
  • 1.Array.of() Array.of() 方法創建一個具有可變數量參數的新數組實例,而不考慮參數的數量或類型...
    bjhu電net閱讀 236評論 0 0
  • 我覺得這個問題是想問,做一件事如何讓自己獲得內在驅動力和外在驅動力? 原因有四個,第一,沒有正確的認知。第二,沒有...
    厭生平閱讀 641評論 2 1