美文网首页
2021年,你必须知道的JS数组技巧

2021年,你必须知道的JS数组技巧

作者: web_zhoua | 来源:发表于2021-10-26 16:36 被阅读0次

    数组是Javascript最常见的概念之一,它为我们提供了处理数据的许多可能性,熟悉数组的一些常用操作是很有必要的。js数组方法大全

    我们在学到js中数组的时候,我们会接触到js中数组的一些方法,这些方法对我们来说,可以很遍历的达到我们想要的结果,但是因为方法比较多,有些方法也不常用,可能会过一段时间就会忘记,那么在这里我整理了21个数组的方法,供大家查阅。

    方法名 对应版本 功能 原数组是否改变
    concat() ES5- 合并数组,并返回合并之后的数据 n
    join() E ES5- 使用分隔符,将数组转为字符串并返回 n
    pop() ES5- 删除最后一位,并返回删除的数据 y
    shift() ES5- 删除第一位,并返回删除的数据 y
    unshift() ES5- 在第一位新增一或多个数据,返回长度 y
    push() ES5- 在最后一位新增一或多个数据,返回长度 y
    reverse() ES5- 反转数组,返回结果 y
    slice() ES5- 截取指定位置的数组,并返回 n
    sort() ES5- 排序(字符规则),返回结果 y
    splice() ES5- 删除指定位置,并替换,返回删除的数据 y
    toString() ES5- 直接转为字符串,并返回 n
    valueOf() ES5- 返回数组对象的原始值 n
    indexOf() ES5 查询并返回数据的索引 n
    lastIndexOf() ES5 反向查询并返回数据的索引 n
    forEach() ES5 参数为回调函数,会遍历数组所有的项,回调函数接受三个参数,分别为value,index,self;forEach没有返回值 n
    map() ES5 同forEach,同时回调函数返回数据,组成新数组由map返回 n
    filter() ES5 同forEach,同时回调函数返回布尔值,为true的数据组成新数组由filter返回 n
    every() ES5 同forEach,同时回调函数返回布尔值,全部为true,由every返回true n
    some() ES5 同forEach,同时回调函数返回布尔值,只要由一个为true,由some返回true n
    reduce() ES5 归并,同forEach,迭代数组的所有项,并构建一个最终值,由reduce返回 n
    reduceRight() ES5 反向归并,同forEach,迭代数组的所有项,并构建一个最终值,由reduceRight返回 n

    以下是数组常用操作

    1、数组去重

    1、from()叠加new Set()方法

    字符串或数值型数组的去重可以直接使用from方法。

    var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    var uniquePlants = Array.from(new Set(plants)); 
    console.log(uniquePlants); // [ 'Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Mars', 'Jupiter' ]
    
    2、spread操作符(…)

    扩展运算符是ES6的一大创新,还有很多强大的功能。

    var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    var uniquePlants = [...new Set(plants)]; 
    console.log(uniquePlants); // [ 'Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Mars', 'Jupiter' ]
    

    2、替换数组中的特定值

    splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。该方法会改变原始数组。特别需要注意插入值的位置!

    // arrayObject.splice(index,howmany,item1,.....,itemX)
    
    var plants = ['Saturn', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    var result = plants.splice(2, 1, 'www.shanzhonglei.com')
    console.log(plants); // ['Saturn','Uranus','www.shanzhonglei.com','Mercury','Venus','Earth','Mars','Jupiter']
    console.log(result); // ['Mercury']
    

    3、没有map()的映射数组

    我们先介绍一下map方法。map()方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值,它会按照原始数组元素顺序依次处理元素。注意: map()不会改变原始数组,也不会对空数组进行检测。
    下面我们来实现一个没有map的数组映射:

    // array.map(function(currentValue,index,arr), thisValue)
    
    var plants = [
        { name: "Saturn" },
        { name: "Uranus" },
        { name: "Mercury" },
        { name: "Venus" },
    ]
    var plantsName = Array.from(plants, ({ name }) => name);
    console.log(plantsName); // [ 'Saturn', 'Uranus', 'Mercury', 'Venus' ]
    

    4、空数组

    如果要清空一个数组,将数组的长度设置为0即可,额,这个有点简单。

    var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    plants.length = 0;
    console.log(plants); // []
    

    5、将数组转换为对象

    如果要将数组转换为对象,最快的方法莫过于spread运算符(...)。

    var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    var plantsObj = {...plants }
    console.log(plantsObj); // {'0': 'Saturn','1': 'Earth', '2': 'Uranus','3': 'Mercury','4': 'Venus','5': 'Earth','6': 'Mars','7': 'Jupiter'}
    

    6、用数据填充数组

    如果我们需要用一些数据来填充数组,或者需要一个具有相同值的数据,我们可以用fill()方法。

    var plants = new Array(8).fill('8');
    console.log(plants); // ['8', '8', '8','8', '8', '8','8', '8']
    

    7、合并数组

    当然你会想到concat()方法,但是哦,spread操作符(...)也很香的,这也是扩展运算符的另一个应用。

    var plants1 = ['Saturn', 'Earth', 'Uranus', 'Mercury'];
    var plants2 = ['Venus', 'Earth', 'Mars', 'Jupiter'];
    console.log([...plants1, ...plants2]); // ['Saturn', 'Earth','Uranus', 'Mercury','Venus', 'Earth','Mars', 'Jupiter']
    

    8、两个数组的交集

    要求两个数组的交集,首先确保数组不重复,然后使用filter()方法和includes()方法。

    var plants1 = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    var plants2 = ['Saturn', 'Earth', 'Uranus'];
    var alonePlants = [...new Set(plants1)].filter(item => plants2.includes(item));
    console.log(alonePlants); // [ 'Saturn', 'Earth', 'Uranus' ]
    

    9、删除数组中的假值

    我们时常需要在处理数据的时候要去掉假值。在Javascript中,假值是false, 0, " ", null, NaN, undefined。

    var plants = ['Saturn', 'Earth', null, undefined, false, "", NaN, 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    var trueArr = plants.filter(Boolean);
    console.log(trueArr); // ['Saturn', 'Earth','Uranus', 'Mercury','Venus', 'Earth','Mars', 'Jupiter']
    

    10、获取数组中的随机值

    我们可以根据数组长度获得一个随机索引号。

    var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    console.log(plants[Math.floor(Math.random() * (plants.length + 1))])
    

    11、lastIndexOf()方法

    lastIndexOf()可以帮助我们查找元素最后一次出现的索引。

    var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter'];
    console.log(plants.lastIndexOf('Earth')) // 5
    

    12、求和

    对数组中的所有元素进行求和,哈哈,又是一道如数家珍的面试题。答案也是很多,条条大道通罗马,这里使用的是reduce,reduce方法是很值得学习的知识点,用处很多

    var nums = [1, 5, 2, 6];
    var sum = nums.reduce((x, y) => x + y);
    console.log(sum); // returns 14
    
    

    换工作?找面试题? 来前端面试题库 wx搜索 进阶的大前端

    相关文章

      网友评论

          本文标题:2021年,你必须知道的JS数组技巧

          本文链接:https://www.haomeiwen.com/subject/cqkyaltx.html