1:Array.from()
Array.from(arrayLike[, mapFn[, thisArg]])
arrayLike
想要转换成数组的伪数组对象或可迭代对象。
mapFn (可选参数)
如果指定了该参数,新数组中的每个元素会执行该回调函数。
thisArg (可选参数)
可选参数,执行回调函数 mapFn 时 this 对象。
返回的是新数组
例子
1:字符串
Array.from('foo'); // ["f", "o", "o"]
2:Set
let s = new Set(['foo', window]);
Array.from(s);
// ["foo", window]
2:Array.reduce()语法
arr.reduce(function(prev,cur,index,arr){
...
}, init);
arr 表示将要原数组;
prev 表示上一次调用回调时的返回值,或者初始值 init;
cur 表示当前正在处理的数组元素;
index 表示当前正在处理的数组元素的索引,若提供 init 值,则索引为0,否则索引为1;
init 表示初始值。
例子
原始数组:let newData1=[1,2,3,4,3,5,6,2];
let newData2=[
{key:1,name:“fangfang”,code:“AAAA”,achievements:80},
{key:2,name:“chenchen”,code:“BBBB”,achievements:90},
{key:3,name:“fangfang”,code:“CCCC”,achievements:86}]
1:数组求和
var sum1=newData1.reduce((prev,next)=>{return prev+next})
var sum2=newData2.reduce((prev,next)=>{return prev+next.achievements},0)
2:数组项的最大值
var max=newData1.reduce((prev,next)=>{
return Math.max(prev,next)
})
var max=newData2.reduce((prev,next)=>{return Math.max(prev,next.achievements)},0)
3:数组去重
var newData = newData1.reduce((prev, next) {
prev.indexOf(next) === -1 && prev.push(next);
return prev;
},[]);
let obj={}
newData2 =newData2 .reduce(function(item,next){
obj[next.key]?"":obj[next.key]=true&&item.push(next);
return item;
},[])
4:数组拼接
var flattened = [[0, 1], [2, 3], [4, 5]].reduce(
( accumulator, currentValue ) => accumulator.concat(currentValue),
[]
);
// flattened is [0, 1, 2, 3, 4, 5]
5:数组中含有相同数量的某个值
var names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];
var countedNames = names.reduce(function (allNames, name) {
if (name in allNames) {
allNames[name]++;
}
else {
allNames[name] = 1;
}
return allNames;
}, {});
// { 'Alice': 2, 'Bob': 1, 'Tiff': 1, 'Bruce': 1 }