JavaScript数组技巧
发布日期:2021-05-11 00:26:20 浏览次数:21 分类:精选文章

本文共 3566 字,大约阅读时间需要 11 分钟。

1、数组去重

//1、from()方法(字符串或数值型数组的去重可以直接使用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()不会改变原始数组,也不会对空数组进行检测// 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、将数组转换为对象

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()方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。// 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优化技巧
下一篇:手写常用JavaScript1.0

发表评论

最新留言

第一次来,支持一个
[***.219.124.196]2025年04月29日 22时31分19秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

2025版最新Bash Shell入门指南,零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新C++快速入门(适合小白)零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新CTF选手必藏的50个实战解题思路,零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新Java教程(非常详细)零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新Kali Linux渗透测试教程(全面详细)零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新LangChain框架快速入门,零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新Metasploit安装使用教程(非常详细)零基础入门到精通,收藏这一篇就够了 2023-01-25
2025版最新Nessus 工具介绍与使用教程,零基础入门到精通,收藏这一篇就够了 2023-01-25
2025版最新wireshark怎么抓包?Wireshark入门指南,零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新一文彻底搞懂大模型 - Agent(非常详细)零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新关于HW护网行动的一些知识,零基础入门到精通,收藏这篇就够了 2023-01-25
(建议收藏)2024最新 URL Scheme大全APP跳转界面地址更新中 ios快捷指令快捷方式链接跳转微信小程序必备autojs可用免root (可定制开发和提取URL Scheme 参数提取) 2023-01-25
2025版最新大模型学习路线,零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新大模型开发流程(非常详细)零基础入门到精通,收藏这一篇就够了 2023-01-25
(干货)数据分析案例--以上海二手房为例 2023-01-25
(大部分安卓手机通用)一加OnePlus Ace3扬声器优化教程 外放直接媲美苹果 2023-01-25
2025版最新大模型微调方法(非常详细)零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新大模型算法岗位薪资指南,零基础入门到精通,收藏这一篇就够了 2023-01-25
2025版最新大语言模型的指令微调,零基础入门到精通,收藏这篇就够了 2023-01-25
2025版最新小白学习大模型:什么是大模型?零基础入门到精通,收藏这篇就够了 2023-01-25