JavaScript 12个有用的数组技巧

2022-04-15 0 582
目录
  • 数组去重
    • 1、from()叠加new Set()方法
    • 2、spread操作符(…)
  • 替换数组中的特定值
    • 没有map()的映射数组
      • 空数组
        • 将数组转换为对象
          • 用数据填充数组
            • 合并数组
              • 两个数组的交集
                • 删除数组中的假值
                  • 获取数组中的随机值
                    • lastIndexOf()方法
                      • 将数组中的所有值相加

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

                        数组去重

                        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' ]

                        替换数组中的特定值

                        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']

                        没有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' ]

                        空数组

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

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

                        将数组转换为对象

                        如果要将数组转换为对象,最快的方法莫过于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'}

                        用数据填充数组

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

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

                        合并数组

                        当然你会想到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']

                        两个数组的交集

                        要求两个数组的交集,首先确保数组不重复,然后使用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' ]

                        删除数组中的假值

                        我们时常需要在处理数据的时候要去掉假值。在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']

                        获取数组中的随机值

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

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

                        lastIndexOf()方法

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

                        // array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
                        
                        var nums = [1, 2, 3, 4, 5];
                        var sum = nums.reduce((x, y) => x + y);
                        console.log(sum); // 15

                        将数组中的所有值相加

                        reduce()方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

                        // array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
                        
                        var nums = [1, 2, 3, 4, 5];
                        var sum = nums.reduce((x, y) => x + y);
                        console.log(sum); // 15

                        到此这篇关于JavaScript 12个有用的数组技巧的文章就介绍到这了,更多相关JavaScript 数组内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!

                        免责声明:
                        1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

                        2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
                        如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
                        如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

                        NICE源码网 JavaScript JavaScript 12个有用的数组技巧 https://www.niceym.com/20816.html