常见的数组操作方法

常见的数组操作方法

1. push()

在数组的末尾添加一个或多个元素,并返回新数组的长度。

let arr = [1, 2, 3];
let newLength = arr.push(4, 5);
console.log(arr); // 输出: [1, 2, 3, 4, 5]
console.log(newLength); // 输出: 5

2. unshift()

在数组的开头添加一个或多个元素,并返回新数组的长度。

let arr = [1, 2, 3];
let newLength = arr.unshift(0);
console.log(arr); // 输出: [0, 1, 2, 3]
console.log(newLength); // 输出: 4

3. pop()

移除数组的最后一个元素,并返回该元素的值。

let arr = [1, 2, 3];
let lastElement = arr.pop();
console.log(arr); // 输出: [1, 2]
console.log(lastElement); // 输出: 3

4. shift()

移除数组的第一个元素,并返回该元素的值。

let arr = [1, 2, 3];
let firstElement = arr.shift();
console.log(arr); // 输出: [2, 3]
console.log(firstElement); // 输出: 1

5. sort()

对数组进行排序,默认是按照字母顺序排序。可以传入一个比较函数来指定排序规则。

let arr = [3, 1, 4, 1, 5, 9];
arr.sort();
console.log(arr); // 输出: [1, 1, 3, 4, 5, 9]

let arr2 = [3, 1, 4, 1, 5, 9];
arr2.sort((a, b) => a - b);
console.log(arr2); // 输出: [1, 1, 3, 4, 5, 9]

6. splice()

用于增加、删除或替换数组中的元素,会改变原数组,返回删除的元素。

删除元素

let arr = [1, 2, 3, 4, 5];
let removed = arr.splice(1, 2);
console.log(arr); // 输出: [1, 4, 5]
console.log(removed); // 输出: [2, 3]

插入元素

let arr = [1, 2, 3, 4, 5];
arr.splice(2, 0, 'a', 'b');
console.log(arr); // 输出: [1, 2, 'a', 'b', 3, 4, 5]

替换元素

let arr = [1, 2, 3, 4, 5];
let replaced = arr.splice(2, 2, 'a', 'b');
console.log(arr); // 输出: [1, 2, 'a', 'b', 5]
console.log(replaced); // 输出: [3, 4]

7. slice()

返回一个新数组,包含从指定开始到结束(不包括结束)的数组元素。

提取指定范围的元素

const originalArray = [1, 2, 3, 4, 5];
const newArray = originalArray.slice(1, 4);
console.log(newArray); // 输出: [2, 3, 4]

复制整个数组

const originalArray = [1, 2, 3, 4, 5];
const newArray = originalArray.slice();
console.log(newArray); // 输出: [1, 2, 3, 4, 5]

从下标为3开始截取到数组的末尾

const originalArray = [1, 2, 3, 4, 5];
const newArray = originalArray.slice(3);
console.log(newArray); // 输出: [4, 5]

从数组最后一个开始截取到倒数第三个

const originalArray = [1, 2, 3, 4, 5];
const newArray = originalArray.slice(-3);
console.log(newArray); // 输出: [3, 4, 5]

8. reverse()

颠倒数组中元素的顺序。

let arr = [1, 2, 3, 4, 5];
arr.reverse();
console.log(arr); // 输出: [5, 4, 3, 2, 1]

9. concat()

连接两个或多个数组,并返回一个新数组。

let arr1 = [1, 2, 3];
let arr2 = [4, 5, 6];
let newArr = arr1.concat(arr2);
console.log(newArr); // 输出: [1, 2, 3, 4, 5, 6]

10. join()

将数组中所有元素连接成一个字符串。可以传入一个字符串参数作为连接符。

let arr = [1, 2, 3];
let str = arr.join('-');
console.log(str); // 输出: "1-2-3"

11. map()

对数组中的每个元素调用提供的函数,并使用函数的返回值创建一个新数组。

let arr = [1, 2, 3];
let newArr = arr.map(x => x * 2);
console.log(newArr); // 输出: [2, 4, 6]

12. filter()

使用提供的函数测试所有元素,并创建一个包含所有通过测试的元素的新数组。

let arr = [1, 2, 3, 4, 5];
let newArr = arr.filter(x => x % 2 === 0);
console.log(newArr); // 输出: [2, 4]

13. every()

检查数组中的每个元素是否满足指定条件,如果所有元素都满足条件则返回 true,否则返回 false。

let arr = [2, 4, 6];
let allEven = arr.every(x => x % 2 === 0);
console.log(allEven); // 输出: true

14. some()

检查数组中的是否至少一个元素满足指定条件,如果有任一元素满足条件则返回 true,否则返回 false。

let arr = [1, 2, 3];
let hasEven = arr.some(x => x % 2 === 0);
console.log(hasEven); // 输出: true

15. reduce()

对数组中的每个元素执行提供的函数,将其结果汇总为单个值。

数组求和

let arr = [1, 2, 3, 4, 5];
let sum = arr.reduce((total, num) => total + num, 0);
console.log(sum); // 输出: 15

16. isArray()

检查给定的值是否是一个数组,返回一个布尔值。

let arr = [1, 2, 3];
let isArray = Array.isArray(arr);
console.log(isArray); // 输出: true

17. findIndex()

返回数组中满足提供的测试函数的第一个元素的索引,如果没有找到匹配的元素则返回 -1。

let arr = [1, 2, 3, 4, 5];
let index = arr.findIndex(x => x === 3);
console.log(index); // 输出: 2

改变原数组的方法

这些方法会改变原数组:push(), pop(), unshift(), shift(), sort(), reverse(), splice()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值