ES6之数组的扩展

2017-04-25  本文已影响0人  嘿喵heyMeow

Array.of( )

将一组数值转换为数组,用来弥补Array()的不足。

Array.of();  //  []
Array.of(1);  //  [1]
Array.of(1,3,5);  //  [1, 3, 5]

Array.from( )

将伪数组或者可遍历的的对象等有length属性的转换为真正的数组。

// 伪数组
var list = document.getElementsByTagName('li');
var arr = Array.from(list);
console.log(arr);  //  [li, li, li]
console.log(arr instanceof Array);  // true

// 字符串
Array.from(‘string’);  // [ 's', 't', 'r', 'i', 'n', 'g' ]

find( )

找出数组中符合条件的第一个元素。
[ ].find(function(value, index, arr)
参数是一个回调函数,数组的每个元素都执行该函数
回调函数的第一个参数:当前值
回调函数的第二个参数:当前值的索引
回调函数的第三个参数:原数组

var arr = [1, 3, 5];
var res = arr.find(function(value, index, arr){
    console.log('index:'+index,'value:'+value);
    console.log(arr);
    console.log('++++++++');
    return value > 1;
});
console.log(res);

// 打印
index:0 value:1
[ 1, 3, 5 ]
++++++++
index:1 value:3
[ 1, 3, 5 ]
++++++++
3

findIndex( )

返回符合条件的第一个元素在数组的位置。
和find()用法差不多。

var arr = [1, 3, 5];
var res = arr.find(function(value, index, arr){
    return value > 1;
});
// res -->> 1

fill( )

将指定元素填充到数组中。
一个参数:数组中所有元素都被替换填充
三个参数:第一个参数是填充的元素,第二个参数是开始填充的位置,第三个参数是结束填充的位置之前

var arr = [1, 3, 5];
arr.fill(2);  // [2, 2, 2]
arr.fill(2,0,2);  // [2, 2, 5]

entries( )、keys( )、values( )

这三个类似,都是通过跟for..of循环配合遍历,得到数组中的元素或索引。

// entries
var arr = [1, 3, 5];
for(let [i, val] of arr.entries()){
    console.log(i,val);
}
// 打印:
0 1
1 3
2 5
// keys
for(let i of arr.keys()){
    console.log(i);
}
//  打印
0
1
2

// values
for(let value of arr.values()){
    console.log(value);
}
//  打印
1
3
5
上一篇 下一篇

猜你喜欢

热点阅读