原生js数组方法的总结,使用的时候便于查询

    // 1.join方法将数组中的数据以指定字符分割成字符串,不影响原数组
    /*         let arr = [1,2,3,4,5]
            console.log(arr.join(","))
            console.log(arr.join("??"))
            // 创建一个空的数组,组合之后就变成了三个间隔字符串的整合
            console.log(new Array(4).join("??"))
            console.log(arr) */
    console.log("---------------------------------")

    // 2.push()末尾添加任意数量参数,返回修改数组长度
    //     pop()末尾移除最后一项,改变length,返回移除项
    /*         let arr = [1, 2, 3, 4, 5, "???"]
            let changeArr = arr.push("a", 'b')
            console.log(arr)
            console.log(changeArr)//输出的是更改后的长度
    
            let popArr = arr.pop();
            console.log(arr)
            console.log(popArr) */

    // 3.shift[去除的意思]删除原数组第一项,与pop对应
    // unshift()在前面添加任意数量参数,与push对应
    /*         let arr = [1, 2, 3, 4, 5, "???"]
            let changeArr = arr.unshift("a", 'b')
            console.log(arr)
            console.log(changeArr)//输出的是更改后的长度
            let popArr = arr.shift();
            console.log(arr)
            console.log(popArr) */

    // 4.sort()升序排序,调用每一项的toString方法比较字符串
    // 可以穿入一个函数进行操作arr.sort(compare)
    //      compare是一个自定义的比较函数
    // reverse()数组倒置,会改变原数组
    /*         let arr = [12, 23, 11, 35, 23, ""]
            console.log(arr.sort())
            console.log(arr)//原数组被改变
            console.log(arr.reverse())
            console.log(arr)//原数组被改变 */

    // 5.concat() :将参数添加到原数组中。
    // 这个方法会先创建当前数组一个副本,
    // 然后将接收到的参数添加到这个副本的末尾,
    // 最后返回新构建的数组。在没有给 concat()方法传递参数的情况下,
    // 它只是复制当前数组并返回副本。
    /*         let arr = [1, 3, 5, 7];
            let arrCopy = arr.concat(9, [11, 13]);
            console.log(arrCopy); //[1, 3, 5, 7, 9, 11, 13]
            console.log(arr); // [1, 3, 5, 7](原数组未被修改)
            let arrCopy2 = arr.concat([9, [11, 13]]);
            console.log(arrCopy2); //[1, 3, 5, 7, 9, Array[2]]
            console.log(arrCopy2[5]); //[11, 13] */

    // 6.slice():返回从原数组中指定开始下标到结束下标之间的项组成的新数组。
    /*         var arr = [1, 3, 5, 7, 9, 11];
            var arrCopy = arr.slice(1);
            var arrCopy2 = arr.slice(1, 4);
            var arrCopy3 = arr.slice(1, -2);
            var arrCopy4 = arr.slice(-4, -1);
            console.log(arr); //[1, 3, 5, 7, 9, 11](原数组没变)
            console.log(arrCopy); //[3, 5, 7, 9, 11]
            console.log(arrCopy2); //[3, 5, 7]
            console.log(arrCopy3); //[3, 5, 7]
            console.log(arrCopy4); //[5, 7, 9] */

    // 7.splice() :很强大的数组方法,它有很多种用法,可以实现删除、插入和替换。
    // 删除:可以删除任意数量的项,只需指定 2 个参数:要删除的第一项的位置和要删除的项数。
    // 例如, splice(0, 2)会删除数组中的前两项。
    // 插入:可以向指定位置插入任意数量的项,只需提供 3 个参数:起始位置、 0(要删除的项数)和要插入的项。
    // 例如,splice(2, 0, 4, 6)会从当前数组的位置 2 开始插入4和6。
    // 替换:可以向指定位置插入任意数量的项,且同时删除任意数量的项,
    // 只需指定 3 个参数:起始位置、要删除的项数和要插入的任意数量的项。插入的项数不必与删除的项数相等。
    // 例如,splice(2, 1, 4, 6)会删除当前数组位置 2 的项,然后再从位置 2 开始插入4和6。
    // splice()方法始终都会返回一个数组,该数组中包含从原始数组中删除的项,如果没有删除任何项,则返回一个空数组。

    // 9、indexOf()和 lastIndexOf()
    // indexOf() :接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的开头(位置 0)开始向后查找。
    // lastIndexOf:接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的末尾开始向前查找。
    // 这两个方法都返回要查找的项在数组中的位置,或者在没找到的情况下返回 - 1。在比较第一个参数与数组中的每一项时,会使用全等操作符。
    // var arr = [1, 3, 5, 7, 7, 5, 3, 1];
    // console.log(arr.indexOf(5)); //2
    // console.log(arr.lastIndexOf(5)); //5
    // console.log(arr.indexOf(5, 2)); //2
    // console.log(arr.lastIndexOf(5, 4)); //2
    // console.log(arr.indexOf("5")); //-1

    // 10、forEach()
    // forEach() :对数组进行遍历循环,对数组中的每一项运行给定函数。这个方法没有返回值
    // var arr = [1, 2, 3, 4, 5];
    // arr.forEach(function (x, index, a) {
    //     console.log(x + '|' + index + '|' + (a === arr));
    // });
    // // 输出为:
    // // 1|0|true
    // // 2|1|true
    // // 3|2|true
    // // 4|3|true
    // // 5|4|true

    // 11、map()
    // map() :指“映射”,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
    // 下面代码利用map方法实现数组中每个数求平方。
    // var arr = [1, 2, 3, 4, 5];
    // var arr2 = arr.map(function (item) {
    //     return item * item;
    // });
    // console.log(arr2); //[1, 4, 9, 16, 25]

    // 12、filter()
    // filter() :“过滤”功能,数组中的每一项运行给定函数,返回满足过滤条件组成的数组。

    // var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
    // var arr2 = arr.filter(function (x, index) {
    //     return index % 3 === 0 || x >= 8;
    // });
    // console.log(arr2); //[1, 4, 7, 8, 9, 10]

    // 13、every()
    // every() :判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true。
    // var arr = [1, 2, 3, 4, 5];
    // var arr2 = arr.every(function (x) {
    //     return x < 10;
    // });
    // console.log(arr2); //true
    // var arr3 = arr.every(function (x) {
    //     return x < 3;
    // });
    // console.log(arr3); // false
    // 14、some()
    // some() :判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。

    // var arr = [1, 2, 3, 4, 5];
    // var arr2 = arr.some(function (x) {
    //     return x < 3;
    // });
    // console.log(arr2); //true
    // var arr3 = arr.some(function (x) {
    //     return x < 1;
    // });
    // console.log(arr3); // false

你可能感兴趣的:(原生js数组方法的总结,使用的时候便于查询)