JavaScript

js数组知识、去重、排序、最大值、求和、合并等大全

2019-09-26  本文已影响0人  Aniugel
    // ES6去重
    //     set是ES6新出来的一种一种定义不重复数组的数据类型
    //     Array.from是将类数组转化为数组
    // ...是扩展运算符, 将set里面的值转化为字符串
    console.log(Array.from(new Set([8, 3, 21, 3, 0, 0])))//[8, 3, 21, 0]
    console.log([...new Set([8, 3, 21, 3, 0, 0])])  //[8, 3, 21, 0]
    // 方法二封装到原型中去
    Array.prototype.qc = function () {
        var arr = [];
        var obj = {};
        var temp = this;
        for (i of this) {
            if (!(i in obj)) {
                obj[i] = 1;
                arr.push(i)
            }
        }
        return arr;
    }
    console.log([1, 2, 3, 44, 44].qc())

    // 排序
    [1, 2, 2, 3, 4, 3, 5, 1].sort()// [1, 1, 2, 2, 3, 3, 4, 5]
    [1, 2, 2, 3, 4, 3, 5, 1].sort((a, b) => b - a)//[1, 2, 3, 4, 5]

    // 最大值 Math.max()是Math对象内置方法,参数是字符串
    Math.max(...[3, 5, 1, 9, 2])//9
    Math.max.apply(this, [3, 5, 1, 9, 2])//9
    [3, 5, 1, 9, 2].reduce((prev, next) => Math.max(prev, next))//9

    // 求和
    [1, 2, 3, 1, 3].reduce((prev, cur) => prev + cur)

    // 合并
    [1, 2, 3, 4].concat([1, 2, 3]);
    [...[1, 99, 2, 6], ...[1, 9]]// ES6结构赋值

    // 每一项设置值 ES6方法
    [1, 2, 4].fill(false)//false, false, false]
    // [1, 2, 4].map(() => false)

    // 每一项是否满足
    [1, 2, 4].every(val => val > 1)//false


    // 有一项是否满足
    [1, 2, 4].some(val => val > 1)//true
    // includes(),find(),findIndex()是ES6的api
    // indexOf()


    // 过滤数组
    [1, 2, 3].filter(item => item > 2)//[3]

    // 对象和数组转化
    Object.keys({ name: '张三', age: 14 })//["name", "age"]
    Object.values({ name: '张三', age: 14 })//["张三", 14]
    Object.entries({ name: '张三', age: 14 })//[["name", "张三"],["age", 14]]

    // 扁平化n维数组 Array.flat(n)是ES10扁平数组的api,n表示维度,n值为Infinity时维度为无限大
    [1, [2, 3]].flat(2) //[1,2,3]
    // [1, [2, 3, [4, 5]].flat(3) //[1,2,3,4,5]
    // [1, [2, 3, [4, 5]]].toString()  //'1,2,3,4,5'
    // [1[2, 3, [4, 5[...]].flat(Infinity) //[1,2,3,4...n]

    //实质是利用递归和数组合并方法concat实现扁平
    // function flatten(arr) {
    //     while (arr.some(item => Array.isArray(item))) {
    //         arr = [].concat(...arr);
    //     }
    //     return arr;
    // }

    const arr = [1, [2, [3], 4], 5]
    function flatten(arr) {
        for (let i in arr) {
            if (Array.isArray(arr[i])) {
                arr.splice(i, 1, ...flatten(arr[i]))
            }
        }
        return arr
    }

    // flatten([1, [2, 3]]) //[1,2,3]
    // flatten([1, [2, 3, [4, 5]]) //[1,2,3,4,5]

    //const arr = [1, [2, [3], 4], 5]
    //JSON.parse(`[${arr}]`);

    // 偶然发现 arr.toString() 或 arr.join() => '1,2,3,4,5'
    // 于是可以写的简便些
    const arr = [1, [2, [3], 4], 5]
    arr.join()
        .split(',')
        .map(it => Number(it))



    // 类数组转换
    Array.prototype.slice.call(arguments) //arguments是类数组(伪数组)
    Array.prototype.slice.apply(arguments)
    Array.from(arguments)
    // [...arguments]
    //     类数组: 表示有length属性, 但是不具备数组的方法
    //     call, apply: 是改变slice里面的this指向arguments, 所以arguments也可调用数组的方法
    //     Array.from是将类似数组或可迭代对象创建为数组
    // ...是将类数组扩展为字符串, 再定义为数组
image.png
上一篇 下一篇

猜你喜欢

热点阅读