总结20个常见的JavaScript数组操作

javascript中的array对象与其他编程语言中的数组一样,是一组数据的集合。在javascript中,数组里面的数据可以是不同类型的,并具有用于执行数组常见操作的方法。

声明数组

有三种不同的声明方式

1. 常规方式

const hobbys = new Array()hobbys[0] = 'Basketball'hobbys[1] = 'Badminton'hobbys[2] = 'swimming'console.log(hobbys)// [ 'Basketball', 'Badminton', 'swimming' ]

2. 简洁方式

const hobbys = new Array('Basketball', 'Badminton','swimming')console.log(hobbys)// [ 'Basketball', 'Badminton', 'swimming' ]

3. 字面

const hobbys = ['Basketball','Badminton','swimming']console.log(hobbys)// [ 'Basketball', 'Badminton', 'swimming' ]

Array 对象方法

1. forEach

forEach() 方法用于调用数组的每个元素,并将元素传递给回调函数。没有返回值,本质上等同于 for 循环,对每一项执行 function 函数。不会改变原数组。

// currentValue:必需,当前元素 index:可选,当前元素的索引值 arr:可选,当前元素所属的数组对象。array.forEach(function(currentValue, index, arr))
let array = ['a', 'b', 'c']let func = (currentValue, index, arr) => {  currentValue += 's'    console.log('currentValue:' + currentValue + ' index:' + index + ' arr:' + arr)}array.forEach(func)console.log(array)// 控制台输出:// currentValue:as index:0 arr:a,b,c// currentValue:bs index:1 arr:a,b,c// currentValue:cs index:2 arr:a,b,c// [ 'a', 'b', 'c' ]

2. map

通过指定函数处理数组的每个元素,并返回处理后的数组。

map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。方法按照原始数组元素顺序依次处理元素。不会改变原数组。

立即学习“Java免费学习笔记(深入)”;

// currentValue:必须,当前元素的值  index:可选,当前元素的索引值 arr:可选,当前元素属于的数组对象array.map(function(currentValue,index,arr))
let array = [1, 2, 3, 4, 5]let result = array.map((item) => {   return item += 5})console.log(array)console.log(result)// [ 1, 2, 3, 4, 5 ]// [ 6, 7, 8, 9, 10 ]

3. concat

JavaScript中的 concat() 方法用来连接两个或更多的数组,并返回结果。

// array1, array2, ..., arrayN 必需,该参数可以是具体的值,也可以是数组对象,可以是任意多个array1.concat(array2,array3,...,arrayN)
const array1 = ['a', 'b', 'c']const array2 = ['d', 'e', 'f']const array3 = array1.concat(array2)console.log(array3)const array4 = array1.concat('123')console.log(array4)// [ 'a', 'b', 'c', 'd', 'e', 'f' ]// [ 'a', 'b', 'c', '123' ]

4. push

Javascript数组中的 push() 方法用来向数组的末尾添加一个或更多元素,并返回新的长度。

let fruits = ["Banana", "Orange", "Apple", "Mango"]let length = fruits.push("Kiwi")console.log(fruits)console.log(length)// [ 'Banana', 'Orange', 'Apple', 'Mango', 'Kiwi' ]// 5

5. unshift

unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。

let fruits = ["Banana", "Orange", "Apple", "Mango"]let length = fruits.unshift("Lemon", "Pineapple")console.log(fruits)console.log(length)// [ 'Lemon', 'Pineapple', 'Banana', 'Orange', 'Apple', 'Mango' ]// 6

6. pop

pop() 方法用于删除数组的最后一个元素并返回删除的元素。

let sites = ['Google', 'Runoob', 'Taobao', 'Zhihu', 'Baidu']let result = sites.pop()console.log(sites)console.log(result)// [ 'Google', 'Runoob', 'Taobao', 'Zhihu' ]// Baidu

7. shift

shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值

let fruits = ["Banana", "Orange", "Apple", "Mango"];let result = fruits.shift()console.log(fruits)console.log(result)// [ 'Orange', 'Apple', 'Mango' ]// Banana

8. splice

splice() 方法用于添加或删除数组中的元素,并返回删除的元素数组

// 参数 Values: index: 必需,规定从何处添加/删除元素// howmany: 可选,规定应该删除多少元素 必须是数字,但可以是 "0"// item1, ..., itemX 可选,要添加到数组的新元素array.splice(index,howmany,item1,.....,itemX)
let fruits = ["Banana", "Orange", "Apple", "Mango"]let result = fruits.splice(1, 2, "Lemon", "Kiwi")console.log(fruits)console.log(result)// [ 'Banana', 'Lemon', 'Kiwi', 'Mango' ]// [ 'Orange', 'Apple' ]

9. slice

slice() 方法可从已有的数组中返回选定的元素。也可提取字符串的某个部分,并以新的字符串返回被提取的部分。不会改变原数组。

先见AI 先见AI

数据为基,先见未见

先见AI 95 查看详情 先见AI

// start: 可选,规定从何处开始选取 若为负值,表示从原数组中的倒数第几个元素开始提取// end: 可选,规定从何处结束选取 如果没有指定该参数,那么切分的数组包含从start到数组结束的所有元素array.slice(start, end)
let fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"]let result1 = fruits.slice(1, 3)let result2 = fruits.slice(2)console.log(fruits)console.log(result1)console.log(result2)// [ 'Banana', 'Orange', 'Lemon', 'Apple', 'Mango' ]// [ 'Orange', 'Lemon' ]// [ 'Lemon', 'Apple', 'Mango' ]

10. join

join() 方法可将所有数组元素结合为一个字符串。它的行为类似 toString(),但是您还可以规定分隔符

// separator: 可选,指定要使用的分隔符 如果省略该参数,则使用逗号作为分隔符array.join(separator)
let fruits = ["Banana", "Orange", "Apple", "Mango"];let energy1 = fruits.join();let energy2 = fruits.join('-');console.log(energy1)console.log(energy2)// Banana,Orange,Apple,Mango// Banana-Orange-Apple-Mango

11. every

every() 方法用于检测数组所有元素是否都符合指定条件(通过函数提供)。

array.every(function(currentValue,index,arr))
let ages = [32, 33, 16, 40]let nums = [32, 33, 19, 40]function checkAdult(age) {  return age >= 18}function checkNums(num) {  return num >= 18}// 16不满足大于18,故结果falselet result1 = ages.every(checkAdult)// 每一项都满足条件,故结果truelet result2 = nums.every(checkNums)console.log(result1)console.log(result2)// false// true

12. filter

filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。不会改变原数组。

array.filter(function(currentValue,index,arr), thisValue)
let ages = [32, 33, 16, 40];function checkAdult(age) {  return age >= 18;}let result = ages.filter(checkAdult)console.log(result)// [ 32, 33, 40 ]

13. indexOf

indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。没有找到会返回-1

// searchvalue: 必需。规定需检索的字符串值。// start: 可选的整数参数。规定在字符串中开始检索的位置。值:0~array.length-1string.indexOf(searchvalue,start)
let str = "Hello world, welcome to the universe.";// 输出w所在的下标索引13(空格也算),没有找到会返回-1let n = str.indexOf("welcome");console.log(n)console.log(str[n])// 13// w

14. reduce

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

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
let numbers = [2, 3, 5, 6]function getSum(total, num) {  return total + num}let result = numbers.reduce(getSum, 0)console.log(result)// 16

15. reverse

reverse() 方法用于颠倒数组中元素的顺序。会改变原数组,并返回改变顺序的数组。

let fruits = ["Banana", "Orange", "Apple", "Mango"]let resut = fruits.reverse()console.log(fruits)console.log(resut)// [ 'Mango', 'Apple', 'Orange', 'Banana' ]// [ 'Mango', 'Apple', 'Orange', 'Banana' ]

16. sort

sort() 方法用于对数组的元素进行排序。排序顺序可以是字母或数字,并按升序或降序。

// sortfunction: 可选。规定排序顺序。必须是函数。array.sort(sortfunction)
let fruits = ["Banana", "Orange", "Apple", "Mango"]let ages = [9, 3, 4, 5, 7, 10]// 升序let agesFunAsc = function (ag1,ag2) {  return ag1 - ag2}// 降序let agesFunDes= function (ag1,ag2) {  return -(ag1 - ag2)}fruits.sort()ages.sort(agesFunAsc)console.log(fruits)console.log(ages)ages.sort(agesFunDes)console.log(ages)// [ 'Apple', 'Banana', 'Mango', 'Orange' ]// [ 3, 4, 5, 7, 9, 10 ]// [ 10, 9, 7, 5, 4, 3 ]

17. toString

toString() 方法用于把数字转换为字符串。

number.toString(radix)
let num = 15let n = num.toString()// 也可以使用不同的进制把一个数字转换为字符串// 2进制let b = num.toString(2);// 8进制let c = num.toString(8);// 16进制let d = num.toString(16);console.log(n)console.log(b)console.log(c)console.log(d)// 15// 1111// 17// f

18. at

at()方法接受整数值并返回at索引的值,正整数和负整数皆可。负整数表示从数组的最后一项开始倒数。

array.at(index)
let str = 'helso word'let item1 = str.at(2)let item2 = str.at(-1)console.log(item1)console.log(item2)// l// d

19. find

find() 方法返回通过测试(函数内判断)的数组的第一个元素的值。

array.find(function(currentValue, index, arr),thisValue)
let ages = [3, 10, 18, 20];function checkAdult(age) {  return age >= 18;}let value = ages.find(checkAdult)console.log(value)// 18

20. some

some() 方法用于检测数组中的元素是否满足指定条件(函数提供)。

array.some(function(currentValue,index,arr),thisValue)
let ages = [3, 10, 19, 20];function checkAdult(age) {  return age > 18;}let result = ages.some(checkAdult)console.log(result)// true

以上就是总结20个常见的JavaScript数组操作的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/541448.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 15:28:53
下一篇 2025年11月9日 15:30:14

相关推荐

  • C++使用VSCode和CMake搭建项目环境方法

    答案是:在VSCode中通过安装编译器、CMake及C++扩展,创建CMakeLists.txt配置项目,利用CMake Tools扩展实现构建与调试。 在VSCode里用CMake搭建C++项目环境,其实就是把VSCode作为你的代码编辑器和调试前端,而CMake则负责生成跨平台的构建系统。核心思…

    2025年12月18日
    000
  • C++如何实现简单的贪吃蛇游戏

    C++实现贪吃蛇的核心在于控制台I/O、非阻塞输入、定时更新与状态管理,使用vector维护蛇身,通过头插尾删实现移动与增长,结合SFML或SDL可升级为图形化游戏。 用C++实现一个简单的贪吃蛇游戏,其实比很多人想象的要直接,它主要依赖于控制台的字符输出和基本的逻辑判断。核心思路是维护一个表示蛇身…

    2025年12月18日
    000
  • C++使用VSCode进行环境配置的步骤

    答案:配置VSCode的C++环境需安装VSCode、选择编译器(如MinGW-w64、MSVC或Clang)、安装C/C++扩展,并配置tasks.json和launch.json文件。具体步骤包括:下载安装VSCode;根据操作系统选择并安装对应编译器,Windows推荐MinGW-w64或MS…

    2025年12月18日
    000
  • C++在MacOS系统上如何安装编译器

    安装C++编译器首选Xcode Command Line Tools,执行xcode-select –install即可安装Clang等核心工具,再通过Homebrew扩展安装GCC或Boost等库,形成完整开发环境。 在macOS系统上安装C++编译器,最直接且推荐的方式是安装Xcod…

    2025年12月18日
    000
  • C++STL算法nth_element和partial_sort使用

    nth_element用于快速定位第n小元素,保证其前后的元素相对有序,平均时间复杂度O(n);partial_sort则将最小的n个元素排序置于前端,时间复杂度O(n log m),适用于Top K场景。根据是否需要有序结果选择:仅需第k元素用nth_element,需前k有序用partial_s…

    好文分享 2025年12月18日
    000
  • C++外观模式封装复杂系统内部逻辑

    外观模式通过提供统一接口简化复杂子系统调用,如CompilerFacade封装词法、语法分析等步骤,降低客户端耦合,提升可维护性。 C++中的外观模式,简单来说,就是为一套复杂的子系统提供一个统一的、高层次的接口。它就像一个总开关,把内部的千头万绪隐藏起来,让外部使用者能更轻松、更直观地操作。这不只…

    2025年12月18日
    000
  • C++访问者模式遍历复杂对象结构操作

    C++访问者模式通过双重分派机制将操作与对象结构分离,使新增操作无需修改元素类,符合开放/封闭原则,提升扩展性与维护性,适用于对象结构稳定但操作多变的场景。 C++的访问者模式(Visitor Pattern)提供了一种优雅的解决方案,用于在不修改复杂对象结构(比如树形结构或复合对象)内部类的前提下…

    2025年12月18日
    000
  • 在C++编程中联合体有哪些经典的应用场景

    联合体在C++中用于内存优化、类型双关和硬件交互,核心价值在于以不同视角解读同一内存数据。其典型应用包括:通过匿名联合体实现事件类型互斥存储,节省内存;利用成员共享内存进行整数与字节数组的相互转换,解析底层数据;结合标签枚举实现可变类型(如AST节点),支持异构数据处理。在嵌入式系统中,联合体可最小…

    2025年12月18日
    000
  • C++如何使用back_inserter和front_inserter插入元素

    back_inserter通过push_back在容器末尾插入,front_inserter通过push_front在开头插入,前者适用于vector等,后者仅用于list、deque等支持前端插入的容器。 在C++中,back_inserter 和 front_inserter 是用于向容器中插入…

    2025年12月18日
    000
  • C++如何实现简易问卷调查程序

    答案是C++简易问卷程序通过定义问题结构、用户交互和文件存储实现,支持文本与单选题,利用枚举区分类型,结构体存储数据,fstream保存结果,可扩展为多态设计以增强灵活性和可维护性。 C++实现一个简易的%ignore_a_1%程序,核心思路其实不复杂:你需要定义好问卷的结构,比如每个问题长什么样,…

    2025年12月18日
    000
  • C++ AR云渲染环境 WebGPU后端开发配置

    答案是C++ AR云渲染结合WebGPU后端需平衡高性能与跨平台,通过Dawn或wgpu-native实现服务器端渲染,利用FFmpeg编码视频流,经WebRTC低延迟传输至客户端,再与AR姿态数据同步叠加显示;其中WebGPU提供现代图形API优势,支持跨平台和浏览器原生集成,而姿态同步需解决网络…

    2025年12月18日
    000
  • VS Code配置C++环境需要安装哪些必要的插件

    最核心且不可或缺的插件是微软官方的C/C++扩展,它提供智能感知、代码导航、调试支持和语法格式化,是VS Code进行C++开发的基础。在此基础上,若使用CMake构建项目,CMake Tools能自动配置、构建和调试;而Code Runner则适合快速运行单文件测试。此外,Better Comme…

    2025年12月18日
    000
  • VS Code如何配置C++17或C++20标准进行编译

    答案是配置tasks.json和c_cpp_properties.json文件。首先确认编译器版本支持C++17/20,然后在tasks.json的args中添加-std=c++17或-std=c++20以指定编译标准,在c_cpp_properties.json中设置cppStandard为&#8…

    2025年12月18日
    000
  • C++量子计算环境 Qiskit库配置方法

    要配置Qiskit库用于C++环境,需通过pybind11创建Python与C++的绑定,使C++程序能调用Qiskit的量子计算功能。首先安装Python、Qiskit和pybind11,然后编写封装Qiskit逻辑的Python模块(如qiskit_logic.py),再用pybind11编写C…

    2025年12月18日
    000
  • C++ deque容器原理 双端队列数据结构

    deque在两端高效插入删除且支持随机访问,适用于需频繁首尾操作并索引访问的场景,其通过分块存储和指针地图实现O(1)首尾增删与O(1)随机访问,相比vector避免了前端移动开销,相比list保留了索引能力,但需注意缓存局部性差、内存开销大及中间操作导致迭代器失效等问题,最佳实践是明确需求、避免中…

    2025年12月18日
    000
  • C++ Linux开发环境 GCC编译器安装指南

    安装GCC是C++开发环境搭建的首要步骤,主流Linux发行版可通过包管理器一键安装,如Debian/Ubuntu使用sudo apt install build-essential,Fedora用sudo dnf install @development-tools,CentOS/RHEL用sud…

    2025年12月18日
    000
  • C++静态分析工具 Clang-Tidy集成指南

    Clang-Tidy通过静态分析在编码阶段提前发现错误、统一代码风格、推广现代C++实践,并与Clang-Format(格式化)、Cppcheck(深度静态分析)等工具协同,形成覆盖代码质量、格式和安全的完整保障体系,尤其在CI/CD中分阶段集成可显著提升团队开发效率与代码可维护性。 将Clang-…

    2025年12月18日
    000
  • C++ WebAssembly编译 Emscripten工具链安装

    答案:通过Emscripten工具链可将C++代码编译为WebAssembly,实现浏览器中高效运行。安装使用emsdk脚本管理工具链,经安装、激活、环境配置后,用emcc编译C++代码并生成HTML、JS、WASM文件,借助本地服务器运行,实现C++与JavaScript交互。 将C++代码带入W…

    2025年12月18日
    000
  • C++ STL迭代器失效 容器修改注意事项

    迭代器失效主因是容器修改导致指向内存无效,不同容器表现不同:vector因连续内存和扩容易失效,list和map因节点式结构更稳定;安全做法包括用erase返回值更新迭代器、避免循环中直接修改、选用合适容器及结合remove_if等算法。 C++ STL迭代器失效,这东西说起来简单,但真要踩坑,那可…

    2025年12月18日
    000
  • 如何将 C++ 框架与前端技术集成?

    将 c++++ 框架与前端技术集成对于构建响应式 web 应用程序至关重要。本指南提供了通过以下步骤实现这一点的方法:设置 c++ 框架(如 boost.asio)和 node.js/react。使用 axios 或 fetch api 在 react 组件中与 c++ 服务器交互。在 c++ 后端…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信