web前端面试题@十二(数组去重,数组扁平化)

一、数组去重

1、利用ES6 Set去重(ES6中最常用)

不考虑兼容性,这种去重的方法代码最少。这种方法还无法去掉“{}”空对象,后面的高阶方法会添加去掉重复“{}”的方法。

es6

2、利用for嵌套for,然后splice去重(ES5中最常用)

双层循环,外层循环元素,内层循环时比较值。值相同时,则删去这个值。

es5

3、利用includes

4、利用hasOwnProperty

二、数组扁平化

    数组扁平化概念

        数组扁平化是指将一个多维数组变为一维数组,例如:[1, [2,3, [4,5]]]  ------>    [1,2,3,4,5]。

    代码实现一下~

        1. reduce

            遍历数组每一项,若值为数组则递归遍历,否则concat。


2 、toString & split

调用数组的toString方法,将数组变为字符串然后再用split分割还原为数组

3、join & split

和上面的toString一样,join也可以将数组转换为字符串

4、递归

递归的遍历每一项,若为数组则继续遍历,否则concat

5、扩展运算符

es6的扩展运算符能将二维数组变为一维

[].concat(...[1, 2, 3, [4, 5]]); // [1, 2, 3, 4, 5]

根据这个结果我们可以做一个遍历,若arr中含有数组则使用一次扩展运算符,直至没有为止。

你可能感兴趣的:(web前端面试题@十二(数组去重,数组扁平化))