javascript数组的一些常用方法详细汇总

 更新时间:2024年09月23日 08:59:03   作者:前端李易安  
在JavaScript开发中,数组的操作至关重要,本文详细介绍了数组的常用方法,包括添加、删除、查找、迭代、遍历、排序和变换等功能,掌握这些方法,可以有效地处理和操作数组数据,提高开发效率和代码的可维护性,需要的朋友可以参考下

前言

在 JavaScript 中,数组是一个非常常用的数据结构,JavaScript 提供了许多方法来操作和处理数组。以下是 JavaScript 中数组的常用方法,分为不同类型进行介绍:

1. 添加/删除元素

  • push():向数组末尾添加一个或多个元素,返回数组的新长度。

    let arr = [1, 2, 3];
    arr.push(4); // arr = [1, 2, 3, 4]
    
  • pop():移除并返回数组最后一个元素。

    let arr = [1, 2, 3];
    let last = arr.pop(); // arr = [1, 2], last = 3
    
  • unshift():向数组开头添加一个或多个元素,返回数组的新长度。

    let arr = [2, 3];
    arr.unshift(1); // arr = [1, 2, 3]
    
  • shift():移除并返回数组第一个元素。

    let arr = [1, 2, 3];
    let first = arr.shift(); // arr = [2, 3], first = 1
    
  • splice(start, deleteCount, item1, item2, ...):从数组中删除、添加或替换元素。返回被删除的元素数组。

    let arr = [1, 2, 3, 4, 5];
    arr.splice(1, 2); // 删除从索引 1 开始的 2 个元素,arr = [1, 4, 5]
    arr.splice(2, 0, 6, 7); // 在索引 2 处插入 6 和 7,arr = [1, 4, 6, 7, 5]
    
  • slice(start, end):返回从 start 到 end(不包括 end)的浅拷贝新数组,不修改原数组。

    let arr = [1, 2, 3, 4, 5];
    let newArr = arr.slice(1, 3); // newArr = [2, 3]
    

2. 查找元素

  • indexOf(item):返回元素在数组中的第一个索引,找不到则返回 -1

    let arr = [1, 2, 3, 4];
    arr.indexOf(3); // 2
    
  • lastIndexOf(item):返回元素在数组中的最后一个索引,找不到则返回 -1

    let arr = [1, 2, 3, 2];
    arr.lastIndexOf(2); // 3
    
  • includes(item):判断数组是否包含某个元素,返回布尔值。

    let arr = [1, 2, 3];
    arr.includes(2); // true
    
  • find(callback):返回满足条件的第一个元素,找不到则返回 undefined

    let arr = [1, 2, 3, 4];
    let found = arr.find(num => num > 2); // 3
    
  • findIndex(callback):返回满足条件的第一个元素的索引,找不到则返回 -1

    let arr = [1, 2, 3, 4];
    let foundIndex = arr.findIndex(num => num > 2); // 2
    

3. 迭代和遍历

  • forEach(callback):对数组中的每个元素执行一次提供的函数(不会返回新数组)。

    let arr = [1, 2, 3];
    arr.forEach(num => console.log(num)); // 输出:1 2 3
    
  • map(callback):对数组中的每个元素执行提供的函数,返回新的数组。

    let arr = [1, 2, 3];
    let newArr = arr.map(num => num * 2); // newArr = [2, 4, 6]
    
  • filter(callback):返回满足条件的元素组成的新数组。

    let arr = [1, 2, 3, 4];
    let filteredArr = arr.filter(num => num > 2); // filteredArr = [3, 4]
    
  • some(callback):如果数组中至少有一个元素满足条件,则返回 true,否则返回 false

    let arr = [1, 2, 3];
    arr.some(num => num > 2); // true
    
  • every(callback):如果数组中每个元素都满足条件,则返回 true,否则返回 false

    let arr = [1, 2, 3];
    arr.every(num => num > 0); // true
    
  • reduce(callback, initialValue):将数组元素组合为一个值,callback 接收四个参数:累计值、当前值、当前索引和原数组。initialValue 是可选的初始累计值。

    let arr = [1, 2, 3, 4];
    let sum = arr.reduce((accumulator, currentValue) => accumulator + currentValue, 0); // sum = 10
    
  • reduceRight(callback, initialValue):从数组的末尾开始执行 reduce 操作。

    let arr = [1, 2, 3, 4];
    let sum = arr.reduceRight((accumulator, currentValue) => accumulator + currentValue, 0); // sum = 10
    

4. 数组排序和变换

  • sort(compareFunction):对数组进行排序,会修改原数组。compareFunction 可选,用于自定义排序规则。

    字符串数组排序

    let fruits = ['banana', 'apple', 'mango'];
    fruits.sort();
    console.log(fruits); // 输出 ['apple', 'banana', 'mango']
    

    数字数组排序对于数字数组,默认排序可能会给出错误的结果,因为默认是将所有值转换成字符串再排序

    let numbers = [8, 2, 3, 5, 1, 10];
    numbers.sort(); // 默认转换为字符串排序,结果可能不是期望的 [1, 2, 3, 5, 8, 10]
    console.log(numbers); // 输出[ 1, 10, 2, 3, 5, 8 ]
    

    为了正确地对数字进行排序,应该提供一个比较函数

    let numbers = [8, 2, 3, 5, 1, 10];
    numbers.sort((a, b) => a - b); 
    console.log(numbers); // 输出[1, 2, 3, 5, 8, 10]
    

    如果想要倒序

    let numbers = [8, 2, 3, 5, 1, 10];
    numbers.sort((a, b) => b - a); 
    console.log(numbers); // 输出[10, 8, 5, 3, 2, 1]
    

    对象数组排序如果你有一个对象数组,并且想要根据某个属性来排序这些对象,可以这样做:

    let people = [
      { name: 'John', age: 23 },
      { name: 'Jane', age: 29 },
      { name: 'Jack', age: 27 }
    ];
    
    // 按年龄排序
    people.sort((a, b) => a.age - b.age);
    console.log(people);
    // 输出:
    // [
    //   { name: 'John', age: 23 },
    //   { name: 'Jack', age: 27 },
    //   { name: 'Jane', age: 29 }
    // ]
    
  • reverse():反转数组顺序,会修改原数组。

    let arr = [1, 2, 3];
    arr.reverse(); // arr = [3, 2, 1]
    
  • join(separator):将数组元素连接成字符串,separator 是可选的分隔符。

    let arr = [1, 2, 3];
    let str = arr.join('-'); // str = "1-2-3"
    
  • concat():合并两个或多个数组,返回新数组,不修改原数组。

    let arr1 = [1, 2];
    let arr2 = [3, 4];
    let newArr = arr1.concat(arr2); // newArr = [1, 2, 3, 4]
    
  • flat(depth):将多维数组“拉平”到指定的深度,默认深度为 1。

    let arr = [1, [2, [3, [4]]]];
    let flatArr = arr.flat(2); // flatArr = [1, 2, 3, [4]]
    
  • flatMap(callback):对每个元素调用映射函数,然后将结果“拉平”一层。

    let arr = [1, 2, 3];
    let flatMapped = arr.flatMap(num => [num, num * 2]); // flatMapped = [1, 2, 2, 4, 3, 6]
    

5. 其他常用方法

  • Array.isArray():检查一个值是否为数组。

    Array.isArray([1, 2, 3]); // true
    
  • fill(value, start, end):用指定值填充数组,start 和 end 是可选的起始和结束位置(不包括结束位置)。

    let arr = [1, 2, 3, 4];
    arr.fill(0, 1, 3); 
    console.log(arr) // 会改变原数组输出:[1, 0, 0, 4]
    
  • from():从类数组或可迭代对象创建一个新数组。

    let arr = Array.from('hello'); 
    console.log(arr) // 输出:['h', 'e', 'l', 'l', 'o']
    
  • of():根据给定的参数创建一个新数组。

     let arr = Array.of(1, 2, 3); 
     console.log(arr) // [ 1, 2, 3 ]

总结 

到此这篇关于javascript数组的一些常用方法的文章就介绍到这了,更多相关js数组常用方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈javascript中this在事件中的应用

    浅谈javascript中this在事件中的应用

    这篇文章主要介绍了浅谈javascript中this在事件中的应用实例,非常有助于我们对this关键字的理解,这里推荐给大家。
    2015-02-02
  • 详解如何构建Promise队列实现异步函数顺序执行

    详解如何构建Promise队列实现异步函数顺序执行

    这篇文章主要介绍了详解如何构建Promise队列实现异步函数顺序执行,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • 时间处理工具 dayjs使用示例详解

    时间处理工具 dayjs使用示例详解

    这篇文章主要为大家介绍了时间处理工具 dayjs使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 基于JavaScript实现全屏透明遮罩div层锁屏效果

    基于JavaScript实现全屏透明遮罩div层锁屏效果

    这篇文章主要介绍了基于JavaScript实现全屏透明遮罩div层锁屏效果的相关资料,需要的朋友可以参考下
    2016-01-01
  • js中apply()和call()的区别与用法实例分析

    js中apply()和call()的区别与用法实例分析

    这篇文章主要介绍了js中apply()和call()的区别与用法,结合实例形式分析了apply()和call()的功能、区别、使用方法及相关操作注意事项,需要的朋友可以参考下
    2018-08-08
  • JS随拖拽速度设置倾斜角度的实现代码

    JS随拖拽速度设置倾斜角度的实现代码

    这篇文章主要给大家介绍了JS如何随拖拽速度设置倾斜角度,文中有详细的代码讲解,对大家的学习或工作有一定的帮助,感兴趣的小伙伴可以自己动手尝试一下
    2023-09-09
  • js实现浮动在网页右侧的简洁QQ在线客服代码

    js实现浮动在网页右侧的简洁QQ在线客服代码

    这篇文章主要介绍了js实现浮动在网页右侧的简洁QQ在线客服代码,通过简单的自定义函数控制客服图片的显示与隐藏效果,非常具有实用价值,需要的朋友可以参考下
    2015-09-09
  • JavaScript实现HTML导航栏下拉菜单

    JavaScript实现HTML导航栏下拉菜单

    这篇文章主要为大家详细介绍了JavaScript实现HTML导航栏下拉菜单,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • 67 个节约开发时间的前端开发者的工具、库和资源

    67 个节约开发时间的前端开发者的工具、库和资源

    在本文中,我不会去谈 React、Angular、Vue 等等这些大的前端框架,也不会谈 Atom、VS code、Sublime 等等这些已经很出名的代码编辑器,我只是想简单的分享一套我认为有助于提升开发者工作流的工具集
    2017-09-09
  • electron中preload.js文件的用法小结

    electron中preload.js文件的用法小结

    preload.js文件在Electron应用中起着桥梁的作用,使得在保持安全的同时,渲染进程可以访问主进程的功能,保持渲染进程与主进程隔离的同时,又能使渲染进程具有访问特定Electron API的能力的方法,本文给大家分享electron中preload.js文件的用法,感兴趣的朋友一起看看吧
    2024-04-04

最新评论