JavaScript 数组操作方法大全(js数组操作的常用方法有哪些)
myzbx 2025-07-03 18:17 3 浏览
数组操作是 JavaScript 中非常重要也非常常用的技巧。本文整理了常用的数组操作方法(包括 ES6 的 map、forEach、every、some、filter、find、from、of 等),熟悉了这些数组操作方法,编写程序也会更加简洁高效。
push()
push()可以将某些值加入到数组的最后一个位置,不限制添加数量,添加的内容使用逗号隔开即可,加入后数组长度会增加。
使用push()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
a.push(9, 10);
console.log(a); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
pop()
pop()会移除 (取出) 数组的最后一个元素。
使用pop()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
let b = a.pop();
console.log(a); // [1, 2, 3, 4, 5, 6, 7]
console.log(b); // 8
shift()、unshift()
shift()会移除 (取出) 数组的第一个元素。
使用shift()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
let b = a.shift();
console.log(a); // [2, 3, 4, 5, 6, 7, 8]
console.log(b); // 1
unshift()会将指定的元素添加到第一个位置。
使用nushift()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
a.unshift(100,200,300);
console.log(a); // [100, 200, 300, 1, 2, 3, 4, 5, 6, 7, 8]
reverse()
reverse()会将数组反转。
使用push()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
a.reverse();
console.log(a); // [8, 7, 6, 5, 4, 3, 2, 1]
splice()
splice()可以移除或新增数组的元素,它包含了三个参数,第一个是要移除或要添加的序列号码 (必填),第二个是要移除的长度 ( 选填,若不填则第一个号码位置后方的所有元素都会被移除,若设定为 0 则不会有元素被移除 ),第三个是要添加的内容 ( 选填 )
使用splice()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
a.splice(5,1);
console.log(a); // [1, 2, 3, 4, 5, 7, 8] ( 6 被移除了 )
设定第三个参数就能够添加或替代元素。
let a = [1,2,3,4,5,6,7,8];
a.splice(5,1,100);
console.log(a); // [1, 2, 3, 4, 5, 100, 7, 8] ( 6 被移除,100 加到第 5 个位置 )
let b = [1,2,3,4,5,6,7,8];
b.splice(5,3,100,200,300);
console.log(b); // [1, 2, 3, 4, 5, 100, 200, 300] ( 6,7,8 被移除,100,200,300 加到第 5,6,7 个位置 )
let c = [1,2,3,4,5,6,7,8];
c.splice(5,0,100);
console.log(c); // [1, 2, 3, 4, 5, 100, 6, 7, 8] ( 没有元素被移除,100 加到第 5 个位置 )
sort()
sort()可以针对数组的元素进行排序,里头包含了一个排序用的判断函数,函数内必须包含两个参数,这两个参数分别代表数组里第 n 个和第 n+1 个元素,通过比较第 n 和第 n+1 个元素的大小来进行排序。
使用sort()后会改变原本的数组内容。
let a = [1,3,8,4,5,7,6,2];
a.sort((x,y) => y - x);
console.log(a); // [8, 7, 6, 5, 4, 3, 2, 1]
a.sort((x,y) => x - y);
console.log(a); // [1, 2, 3, 4, 5, 6, 7, 8]
如果不使用判断函数,默认会将元素转换成字符串,并采用 unicode 来判断,这也会造成某些数字的排序错误。
let a = [1,3,8,4,5,7,6,2,9,10,11];
a.sort();
console.log(a); // [1, 10, 11, 2, 3, 4, 5, 6, 7, 8, 9]
copyWithin()
copyWithin()能复制数组中的某些元素,并将它们放到并取同一个数组指定的位置,copyWithin()有三个参数,第一个是要替换的位置 (必填),第二个是从什么位置开始复制 ( 选填,默认 0 ),第三个是停止复制的元素的前一个位置 ( 选填,默认等于数组长度 )。
使用copyWithin()后会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
a.copyWithin(2);
console.log(a); // [1,2,1,2,3,4,5,6] ( 因 7 和 8 超过数组长度,只出现到 6 )
let b = [1,2,3,4,5,6,7,8];
b.copyWithin(3,1,3);
console.log(b); // [1,2,3,2,3,6,7,8] ( 复制 2,3 替代 4,5 )
fill()
fill()会把数组中所有元素,替换为指定的值,fill()有三个参数,第一个是准备要替换的内容 (必填),第二个是从什么位置开始替换 ( 选填,不设定就全部替换 ),第三个是停止替换的元素的前一个位置 ( 选填,默认等于数组长度 )。
使用fill()会改变原本的数组内容。
let a = [1,2,3,4,5,6,7,8];
a.fill('a');
console.log(a); // ['a','a','a','a','a','a','a','a']
let b = [1,2,3,4,5,6,7,8];
b.fill('b',3,5);
console.log(b); // [1,2,3,'b','b',6,7,8]
length()
length可以取得数组的长度 (所有元素的数量)。
let a = [1,2,3,4,5,6,7,8];
console.log(a.length); // 8
indexOf()、lastIndexOf()
indexOf()会判断数组中是否包含某个值,判断的方式为「由左而右」,如果有包含就返回这个值在数组中的索引值,如果没有就返回 -1,有两个参数,第一个参数表示要判断的值 (必填),第二个参数表示从数组的哪个位置开始判断 ( 选填,默认为 0 )。
let a = [1,2,3,4,5,6,7,8];
console.log(a.indexOf(4)); // 3
console.log(a.indexOf(4,5)); // -1 ( 搜索 5,6,7,8 没有 4 )
lastIndexOf()会判断数组中是否包含某个值,判断的方式为「由右而左」,如果有包含就返回这个值在数组中的索引值,如果没有就返回 -1,有两个参数,第一个参数表示要判断的值 (必填),第二个参数表示判断到数组的哪个位置 ( 选填,默认为整个数组长度 - 1 )。
let a = [1,2,3,4,5,6,7,8];
console.log(a.lastIndexOf(3)); // 2
console.log(a.lastIndexOf(3,1)); // -1 ( 只判断 1,2,所以没有 3 )
find()
find()会将数组中的「每一个」元素带入指定的函数内做判断,并会返回第一个符合判断条件的元素,如果没有元素符合则会返回 undefined。
let a = [1,2,3,4,5,6,7,8];
console.log(a.find(e => e > 3)); // 4
console.log(a.find(e => e < 0)); // undefined
findIndex()
findIndex()会将数组中的「每一个」元素带入指定的函数内做判断,并会返回第一个符合判断条件元素的位置号码,如果没有元素符合则会返回 -1。
let a = [1,2,3,4,5,6,7,8];
console.log(a.findIndex(e => e > 3)); // 3
console.log(a.findIndex(e => e < 0)); // -1
filter()
filter()会将数组中的「每一个」元素带入指定的函数内做判断,如果元素符合判断条件则会返回,成为一个新的数组元素。
let a = [1,2,3,4,5,6,7,8];
console.log(a.filter(e => e > 3)); // [4, 5, 6, 7, 8]
console.log(a.filter(e => e%2 == 0)); // [2, 4, 6, 8]
forEach()
forEach()会将数组中每个元素套用到指定的函数里进行运算,函数有三个参数,第一个参数表示每个元素的值 (必填),第二个参数为该元素的索引值 ( 选填 ),第三个参数则表示原本的数组 ( 选填 )。
let a = [1,2,3,4,5];
let b = 0;
a.forEach(item => {
b = b + item;
});
console.log(b); // 15 ( 1+2+3+4+5 )
如果通过第二和第三个参数搭配,就能做到改变原本数组的效果。
let a = [1,2,3,4,5];
a.forEach((item, index, arr) => {
arr[index] = item * 10;
});
console.log(a); // [10,20,30,40,50]
join()
join()可以将数组中所有元素,由指定的字符合并在一起变成字符串呈现,若没有指定字符默认会用「逗号」合并。
let a = [1,2,3,4,5,6,7,8];
console.log(a.join()); // 1,2,3,4,5,6,7,8
console.log(a.join('')); // 12345678
console.log(a.join('@@')); // 1@@2@@3@@4@@5@@6@@7@@8
concat()
concat()可以将两个数组合并在一起,如果是使用 ES6 语法也可以用扩展运算符...来代替。
let a = [1,2,3,4,5];
let b = [6,7,8,9];
let c = a.concat(b);
let d = [...a, ...b]; // 使用 ...
console.log(c); // [1,2,3,4,5,6,7,8,9]
console.log(d); // [1,2,3,4,5,6,7,8,9]
slice()
slice()可以截取出数组某部份的元素为一个新的数组,有两个必填的参数,第一个是起始位置,第二个是结束位置 (操作时数字减 1)。
let a = [1,2,3,4,5,6,7,8];
let b = a.slice(2,4);
console.log(b); // [3, 4]
map()
map()会处理数组中每个元素,最后返回出一个新的数组,里头有一个函数 (必填) 和一个返回函数里的 this 参数 ( 选填 ),函数内又包含三个参数,第一个是每个元素的值 ( 必填 ),第二个是当前元素的索引值 ( 选填 ),第三个是当前的数组 ( 选填 )。
let a = [1,2,3,4,5,6,7,8];
let b = a.map(e => {
return e + 10;
});
console.log(b); // [11, 12, 13, 14, 15, 16, 17, 18]
套用第二个和第三个参数的变化
let a = [1,2,3,4,5,6,7,8];
let b = a.map((e,i,arr) => {
return `${e}${i}${arr.find(e => e%5 == 1)}`; // 组合成「元素 + 索引值 + 除以五余数为 1 的元素」
});
console.log(b); // ['101', '211', '321', '431', '541', '651', '761', '871']
如果要使用返回函数里 this 的参数,则「不能使用」箭头函数,因为箭头函数的 this 指向和函数的 this 指向不同,所以要用一般的函数处理。
let a = [1,2,3,4,5,6,7,8];
let b = a.map(function(e){
return e + this; // 此处的 this 为 10
}, 10);
console.log(b); // [11, 12, 13, 14, 15, 16, 17, 18]
reduce()、reduceRight()
reduce()可以将数组中每个元素进行计算,每次计算的结果会再与下个元素作计算,直到结束为止,里头包含一个函数 (必填) 和初始计算的数值 ( 选填 ),函数内有四个参数,第一个是计算的值 ( 必填 ),第二个是取得的元素 ( 必填 ),第三个是该元素的索引值 ( 选填 ),第四个是原本的数组 ( 选填 )。
let a = [1,2,3,4,5,6,7,8];
let b = a.reduce(function(total, e){
return total + e;
});
console.log(b); // 36 ( 1+2+3+4+5+6+7+8=36 )
reduceRight()和reduce()大同小异,只是其计算方式是由右到左,对于加法来说没什么影响,但对于减法而言就有差异。
let a = [1,2,3,4,5,6,7,8];
let b = a.reduce(function(total, e){
return total - e;
});
console.log(b); // -34 ( 1-2-3-4-5-6-7-8 = -34 )
let c = a.reduceRight(function(total, e){
return total - e;
});
console.log(c); // -20 ( 8-7-6-5-4-3-2-1 = -20 )
flat()
flat()可以将一个多维数组的深度转成一维 (扁平化),它有一个选填的参数,代表要转换的深度数字,默认为 1,如果深度有很多层,可使用Infinity来全部展开成一维数组。
let a = [1,2,[3],[4,[5,[6]]]];
let b = a.flat();
let c = a.flat(2);
let d = a.flat(Infinity);
console.log(b); // [1, 2, 3, 4, [5, [6]]]
console.log(c); // [1, 2, 3, 4, 5, [6]]
console.log(d); // [1, 2, 3, 4, 5, 6]
flatMap()
flatMap()的方法等于map()和flat()的组合,在运算后直接将数组扁平化处理。
let a = [1,2,[3],[4,5]];
let b = a.flatMap(e => e+1);
let c = a.map(e => e+1).flat();
console.log(b); // [2, 3, "31", "4,51"] ( 可以看到 b 和 c 得到的结果相同 )
console.log(c); // [2, 3, "31", "4,51"]
Array.isArray()
Array.isArray()能判断一个对象是否为数组,如果是就返回 true,不然就返回 false。
let a = [1,2,3,4,5,6,7,8];
let b = 123;
let c = 'hello';
let d = {d1:1,d2:2};
console.log(Array.isArray(a)); // true
console.log(Array.isArray(b)); // false
console.log(Array.isArray(c)); // false
console.log(Array.isArray(d)); // false
Array.from()
Array.from()会将「类数组对象」或是「可迭代的对象」转换成数组,Array.from()有两个参数,第一个参数为「类数组对象」或「可迭代的对象」(必填),第二个参数则是改变转换成数组元素的函数 ( 选填 )。
类数组对象具有 length 属性以及索引化 index 的元素,可迭代对象表示具有可以利用迭代的方式取得它自己本身的元素,例如 Map 和 Set... 等。(参考 MDN 说法)
let a = 'abcde';
let b = Array.from(a);
console.log(b); // ['a','b','c','d','e']
let c = Array.from(a, e => e + e);
console.log(c); // ['aa','bb','cc','dd','ee']
类数组对象写法必须包含 length 属性,且对象 key 须为 0 开始的数字,对应转换后的元素索引。
let a = {
'0': 14,
'2': 13,
'1': 7,
'3': 9,
'4': 6,
length: 5
};
let b = Array.from(a);
console.log(b); // [14,7,13,9,6]
Array.of()
Array.of()可以快速将数字、字符串等内容,转换成数组。
let a = Array.of(1,'a',2,'b',3);
console.log(a); // [1, "a", 2, "b", 3]
toString()
toString()会把整个数组转换成文字。
let a = [1,2,3,4,5,6,7,8];
let b = a.toString();
console.log(b); // 1,2,3,4,5,6,7,8
every()
every()会将数组中的「每一个」元素带入指定的函数内做判断,只要有任何一个元素不符合判断条件,会返回 false,如果全部符合,就会返回 true。
let a = [1,2,3,4,5,6];
console.log(a.every(e => e > 3)); // fasle ( 因为 1、2 小于 3,3 等于 3 )
console.log(a.every(e => e > 0)); // true
some()
some()会将数组中的「每一个」元素带入指定的函数内做判断,只要有任何一个元素符合判断条件,就会返回 true,如果全都不符合,就会返回 false。
let a = [1,2,3,4,5,6];
console.log(a.some(e => e > 3)); // 返回 true,因为 4、5、6 大于 3
console.log(a.some(e => e > 6)); // 返回 fasle,因为全都小于或等于 6
includes()
includes()会判断数组中是否包含某个值,如果有包含就返回 true,否则返回 false,有两个参数,第一个参数表示要判断的值 (必填),第二个参数表示从数组的哪个位置开始判断 ( 选填 )。
let a = [1,2,3,4,5,6,7,8];
console.log(a.includes(2)); // true
console.log(a.includes(2,2)); // false ( 搜索 3,4,5,6,7,8 没有 2 )
valueOf()
valueOf()会返回数组的原始值,如果原本的数组有修改,那么返回的原始值也会跟着改变
let a = [1,2,3,4,5,6,7,8];
let b = a.valueOf();
console.log(a); // [1, 2, 3, 4, 5, 6, 7, 8]
let c = a.valueOf();
a.shift();
console.log(a); // [2, 3, 4, 5, 6, 7, 8]
console.log(b); // [2, 3, 4, 5, 6, 7, 8] ( 因为 a 的原始值更动了,所以 b 也变了 )
console.log(c); // [2, 3, 4, 5, 6, 7, 8]
keys()
keys()会返回数组中的每一个索引值 (key) 成为一个新的 Array Iterator 对象,因为是 Array Iterator 对象,可以通过for...of来取得。
let a = ['a','b','c','d','e'];
let b = a.keys();
for (let key of b) {
console.log(key); // 连续出现 1、2、3、4、5
}
javascript2
相关推荐
- C语言速成之数组:C语言数据处理的核心武器,你真的玩透了吗?
-
程序员Feri一名12年+的程序员,做过开发带过团队创过业,擅长Java、鸿蒙、嵌入式、人工智能等开发,专注于程序员成长的那点儿事,希望在成长的路上有你相伴!君志所向,一往无前!数组:C语言数据处理...
- ES6史上最全数JS数组方法合集-02-数组操作
-
数组生成array.ofletres=Array.of(1,2,3)console.log(res)//[1,2,3]下标定位indexOf用于查找数组中是否存在某个值,如果存...
- 前端性能拉胯?这 8 个 JavaScript 技巧让你的代码飞起来!
-
在前端开发的江湖里,JavaScript就是我们手中的“绝世宝剑”。但为啥别人用剑就能轻松斩敌,你的代码却总拖后腿,页面加载慢、交互卡顿?别着急!今天带来8个超实用的JavaScript实...
- 12种JavaScript中最常用的数组操作整理汇总
-
数组是最常见的数据结构之一,我们需要绝对自信地使用它。在这里,我将列出JavaScript中最重要的几个数组常用操作片段,包括数组长度、替换元素、去重以及许多其他内容。1、数组长度大多数人都知道可...
- 手把手教你在Webpack写一个Loader
-
前言有的时候,你可能在从零搭建Webpack项目很熟悉,配置过各种loader,面试官在Webpack方面问你,是否自己实现过一个loader?如果没有去了解过如果去实现,确实有点尴尬,其...
- const关键字到底该什么用?(可以用const关键字定义变量吗)
-
文|守望先生经授权转载自公众号编程珠玑(id:shouwangxiansheng)前言我们都知道使用const关键字限定一个变量为只读,但它是真正意义上的只读吗?实际中又该如何使用const关键字...
- “JavaScript变量声明三兄弟,你真的会用吗?
-
在JavaScript中,var、let和const是声明变量的关键字,它们在作用域、变量提升、重复声明和重新赋值等方面有显著区别。以下是它们的相同点和不同点,并通过代码示例详细说明。一、相同点声明变...
- ES6(二)let 和 const(es6 var let const区别)
-
let命令let和var差不多,只是限制了有效范围。先定义后使用不管是什么编程语言,不管语法是否允许,都要秉承先定义,然后再使用的习惯,这样不会出幺蛾子。以前JavaScript比较随意,...
- js 里面 let 和 const的区别(js中的let)
-
在JavaScript(包括Vue、Node.js、前端脚本等)中,const和let是用于声明变量的两种方式,它们的主要区别如下:constvslet的区别特性constlet是否...
- JDK21新特性:Sequenced Collections
-
SequencedCollectionsJDK21在JEP431提出了有序集合(SequencedCollections)。引入新的接口来表示有序集合。这样的集合都有一个明确的第一个元素、第二个...
- 动态编程基础——第 2 部分(动态编程是什么)
-
有两种方法可以使用动态规划来解决问题。在这篇文章中,我们将了解制表法。请参阅我的动态编程基础——第1部分了解记忆方法。记忆制表什么是动态规划?它是一种简单递归的优化技术。它大大减少了解决给定...
- Lambda 函数,你真的的了解吗(lambda函数用法)
-
什么是lambda函数lambda函数是一个匿名函数,这意味着与其他函数不同,它们没有名称。这是一个函数,它添加两个数字,写成一个命名函数,可以按其名称调用它们:defadd(x,y):...
- JavaScript 数组操作方法大全(js数组操作的常用方法有哪些)
-
数组操作是JavaScript中非常重要也非常常用的技巧。本文整理了常用的数组操作方法(包括ES6的map、forEach、every、some、filter、find、from、of等)...
- 系列专栏(六):解构赋值(解构赋值默认值)
-
ES6作为新一代JavaScript标准,已正式与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,MozillaWeb开发者博客推出了《ES6InDepth》系列文章。CSDN...
- js列表遍历方法解读(js遍历链表)
-
JavaScript提供了多种遍历数组(或列表)的方法。以下是一些常用的方法及其解读:for循环:vararray=[1,2,3,4,5];for(vari=0;...
- 一周热门
- 最近发表
-
- C语言速成之数组:C语言数据处理的核心武器,你真的玩透了吗?
- ES6史上最全数JS数组方法合集-02-数组操作
- 前端性能拉胯?这 8 个 JavaScript 技巧让你的代码飞起来!
- 12种JavaScript中最常用的数组操作整理汇总
- 手把手教你在Webpack写一个Loader
- const关键字到底该什么用?(可以用const关键字定义变量吗)
- “JavaScript变量声明三兄弟,你真的会用吗?
- ES6(二)let 和 const(es6 var let const区别)
- js 里面 let 和 const的区别(js中的let)
- JDK21新特性:Sequenced Collections
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)