map函数,可以返回x的f(x)

reduce可以累积结果,例如累计求和

filter可以过滤不满足条件的数据 

这里提一下reduce,map.reduce就可以将前面f(x)的值进行某些操作合并起来,在map之前或者之后需要过滤再搭配一个filter,这感觉可以做到一些很妙的操作。

这里有一个reduce栗子,将arr阔号展开来,得到[1,2,3,c,d,7,8,4,5,6]

let arr = [1, 2, [[3, ['c', ['d',[7,8]]], 4], 5], 6];
const Judge=x=>{return x instanceof Array && x.some(e => { return (e instanceof Array) });};
const F1 = (p, x) => { return p.concat(x) };
const F2 = x => x.reduce(F1, []);
const F3 = (x) => {
let answer=F2(x);
while (Judge(answer))answer=F2(answer);
return answer;
};
console.log(F3(arr))

这个阔号嵌套层数很多,感觉得while

F2给reduce第二个参数一个空阔号初始化,可以将元素内的数组通过F1拆开来合并在一起

F1就是简单的数组合并

F3对每轮合并结果进一步判断是否还有数组元素,继续拆分合并。