JS数组的常用10种方法详解

1、arr.push()

作用:将一个或多个元素添加到数组的末尾,并返回该数组的新长度。
参数:被添加到数组末尾的元素。
返回值:新的 length 属性值

var sports = ["soccer", "baseball"];
var total = sports.push("football", "swimming");
console.log(sports);
// ["soccer", "baseball", "football", "swimming"]
console.log(total);
// 4

2、arr.pop()

作用:从数组中删除最后一个元素,并返回该元素的值。此方法更改数组的长度。
返回值:从数组中删除的元素(当数组为空时返回undefined)。

let myFish = ["angel", "clown", "mandarin", "surgeon"];
let popped = myFish.pop();
console.log(myFish);
// ["angel", "clown", "mandarin"]
console.log(popped);
// surgeon

3、unshift()

作用: 将一个或多个元素添加到数组的开头,并返回该数组的新长度(该方法修改原有数组)。
参数: 要添加到数组开头的元素或多个元素。
返回值:新的 length 属性值

let arr = [4, 5, 6];
let newArr = arr.unshift(1, 2, 3);
console.log(arr); 
// [1, 2, 3, 4, 5, 6]
console.log(newArr);
// 6

4、shift()

作用:从数组中删除第一个元素,并返回该元素的值。此方法更改数组的长度。
返回值:从数组中删除的元素; 如果数组为空则返回undefined。

let myFish = ['angel', 'clown', 'mandarin', 'surgeon']
let shifted = myFish.shift();
console.log(myFish);
// ['clown', 'mandarin', 'surgeon']
console.log(shifted);
// clown

5、concat()

作用:用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组。
参数:数组和/或值,被合并到一个新的数组中。如果省略了所有参数,则 concat 会返回调用
返回值:新的 Array 实例。

连接两个数组

let alpha = ['a', 'b', 'c'];
let numeric = [1, 2, 3];
alpha.concat(numeric);
// ['a', 'b', 'c', 1, 2, 3]

将值连接到数组

let alpha = ['a', 'b', 'c'];
let alphaNumeric = alpha.concat(1, [2, 3]);
console.log(alphaNumeric);
//  ['a', 'b', 'c', 1, 2, 3]

合并嵌套数组

let num1 = [[1]];
let num2 = [2, [3]];
let nums = num1.concat(num2);
console.log(nums);
// [[1], 2, [3]]

6、splice()

作用: 通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回 被修改的内容。此方法会改变原数组
参数:
(1)start:指定修改的开始位置(从0计数),如果超出了数组的长度,则从数组末尾开始添加内容如果是负值,则表示从数组末位开始的第几位
(2)deleteCount:整数,表示要移除的数组元素的个数,可选
如果 deleteCount 被省略了,那么start之后数组的所有元素都会被删除。
如果 deleteCount 是 0 或者负数,则不移除元素。这种情况下,至少应添加一个新元素。
(3)item1, item2, …:要添加进数组的元素,从start 位置开始。如果不指定,则 splice() 将只删除数组元素,可选
返回值:由被删除的元素组成的一个数组

(1)从索引 2 的位置开始删除 1 个元素,插入“trumpet”

let myFish = ['angel', 'clown', 'drum', 'sturgeon'];
let removed = myFish.splice(2, 1, "trumpet");
console.log(myFish);
// ["angel", "clown", "trumpet", "sturgeon"]
console.log(removed);
// ["drum"]

(2)从索引 -2 的位置开始删除 1 个元素

let myFish = ['angel', 'clown', 'mandarin', 'sturgeon'];
let removed = myFish.splice(-2, 1);
console.log(myFish);
// ["angel", "clown", "sturgeon"]
console.log(removed);
// ["mandarin"]

(3)从索引 2 的位置开始删除所有元素

let myFish = ['angel', 'clown', 'mandarin', 'sturgeon'];
let removed = myFish.splice(2);
console.log(myFish);
// ["angel", "clown"]
console.log(removed);
// ["mandarin", "sturgeon"]

7、slice()

作用: 返回一个新的数组对象,这一对象是一个由 begin 和 end 决定的原数组的浅拷贝(包括 begin,不包括end)。原始数组不会被改变。
参数:
(1)begin 可选
提取起始处的索引(从 0 开始)
如果该参数为负数,则表示从原数组中的倒数第几个元素开始提取
如果省略 begin,则 slice 从索引 0 开始。
如果 begin 超出原数组的索引范围,则会返回空数组。
(2)end 可选
提取终止处的索引(从 0 开始)
在该索引处结束提取原数组元素
slice 会提取原数组中索引从 begin 到 end 的所有元素(包含 begin,但不包含 end)。
如果该参数为负数, 则它表示在原数组中的倒数第几个元素结束抽取
如果 end 被省略或大于数组的长度,则 slice 会一直提取到原数组末尾。
返回值:一个含有被提取元素的新数组。

let fruits = ['Banana', 'Orange', 'Lemon', 'Apple', 'Mango'];
let citrus = fruits.slice(1, 3);
console.log(fruits);
// ['Banana', 'Orange', 'Lemon', 'Apple', 'Mango']
console.log(citrus);
// ['Orange','Lemon']

8、join()

作用: 将一个数组(或一个类数组对象)的所有元素连接成一个字符串并返回这个字符串。如果数组只有一个项目,那么将返回该项目而不使用分隔符。
参数:
separator 可选,用来指定一个字符串来分隔数组的每个元素
如果缺省该值,数组元素用逗号(,)分隔。
如果是空字符串(""),则所有元素之间都没有任何字符。
返回值:一个所有数组元素连接的字符串。如果 arr.length 为0,则返回空字符串。

let a = ['Wind', 'Rain', 'Fire'];
let myVar1 = a.join();      // myVar1的值变为"Wind,Rain,Fire"
let myVar2 = a.join(', ');  // myVar2的值变为"Wind, Rain, Fire"
let myVar3 = a.join(' + '); // myVar3的值变为"Wind + Rain + Fire"
let myVar4 = a.join('');    // myVar4的值变为"WindRainFire"

9、sort()

作用: 对数组的元素进行排序,并返回数组,默认排序顺序是在将元素转换为字符串,然后比较它们的UTF-16代码单元值序列时构建的。
参数: compareFunction 可选
firstEl 第一个用于比较的元素。
secondEl 第二个用于比较的元素。
返回值:排序后的数组

let numbers = [4, 2, 5, 1, 3];
numbers.sort(function(a, b) {
  return a - b;
});
console.log(numbers);
// [1, 2, 3, 4, 5]

10、reverse()

作用: 将数组中元素的位置颠倒,并返回该数组,该方法会改变原数组。
返回值:颠倒后的数组。

const a = [1, 2, 3];
console.log(a); 
// [1, 2, 3]
a.reverse();
console.log(a); 
// [3, 2, 1]
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中有多种方法可以遍历数组,其中常用的有map、forEach和filter。 1. map方法: map方法会对数组中的每个元素调用一个回调函数,并返回一个新的数组,新数组的元素是原始数组中每个元素经过回调函数处理后的结果。例如,我们有一个数组[1, 2, 3],我们可以使用map方法将每个元素乘以2并返回一个新的数组[2, 4, 6]。map方法不会改变原始数组。 2. forEach方法: forEach方法会对数组中的每个元素调用一个回调函数,但它不会返回任何内容。通常,forEach方法用于执行一些操作而不需要返回结果,例如打印数组中的每个元素。与map方法不同,forEach方法无法返回修改后的数组。 3. filter方法: filter方法会对数组中的每个元素调用一个回调函数,并返回一个新的数组,新数组的元素是回调函数返回值为true的元素。例如,我们有一个数组[1, 2, 3, 4, 5],我们可以使用filter方法筛选出所有大于2的元素并返回一个新的数组[3, 4, 5]。与map方法类似,filter方法也不会改变原始数组。 这三种方法在遍历数组时具有不同的用途。map方法可以用于对数组中的每个元素进行转换或操作,并返回一个新的数组。forEach方法用于执行一些操作而不关心返回值。filter方法用于根据指定的条件筛选出符合条件的元素,并返回一个新的数组。根据具体情况,我们可以选择合适的方法来遍历数组

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值