数组常用方法

数组基本操作可以归纳为 增 删 改 查。

 

需要留意的是哪些方法会对原数组产生影响,哪些方法不会。

 

## 增

 

**push、unshift、splice、concat。**

 

下面前三种是对原数组产生影响的增添方法,**第四种则不会对原数组产生影响**。

 

- push()
 
push()方法接收任意数量的参数,并将它们添加到数组末尾。返回数组的最新长度。

 

```js
let colors = [];
let count = colors.push("red", "yellow", "blue");
console.log(count); // 3
```

 

- unshift()

 

unshift()在数组开头添加任意多个值。返回数组的最新长度。

 

```js
let fruit = ["apple", "banana", "pear"];
let count = fruit.unshift("peach", "strawberry", "pineapple");
console.log(fruit); // ["peach", "strawberry", "pineapple", "apple", "banana", "pear"]
console.log(count); // 6
```

 

- splice()

 

传入三个参数,分别是开始位置、要删除的元素数量、插入的元素,**返回[]**。

 

```js
// 1 push
let fruit = ["apple", "banana", "pear"];
let removed = fruit.splice(fruit.length, 0, "a", "b");
console.log(fruit); // ["apple", "banana", "pear", "a", "b"]
console.log(removed); // []

 

// 2 unshift
let fruit = ["apple", "banana", "pear"];
let removed = fruit.splice(0, 0, "a", "b");
console.log(fruit); // ["a", "b", "apple", "banana", "pear"]
console.log(removed); // []

 

// 3 在中间 某个位置 插入数据
let fruit = ["apple", "banana", "pear"];
let removed = fruit.splice(1, 0, "a", "b");
console.log(fruit); // ["apple", "a", "b", "banana", "pear"]
console.log(removed); // []

 

```

 

- concat()

 

首先会创建一个当前数组的副本,然后再把它的参数添加到副本末尾,最后返回这个新构建的数组,不会影响原始数组。

 

```js
let arr = [1, 2, 3];
let arr2 = ["a", "b", "c"];
let newArr = [].concat(arr, arr2, ["red", "yellow", "blue", "green"]);
console.log(newArr); // [1, 2, 3, "a", "b", "c", "red", "yellow", "blue", "green"]
```

 

## 删

 

下面三种都会影响原数组,最后一项不影响原数组。

 

**pop、shift、splice、slice。**

 

- pop()

 

pop()方法用于删除数组的最后一项,同时减少数组的`length`值,返回被删除的项。

 

```js
let colors = ["red", "green", "blue", "pink"];
let item = colors.pop(); // 取得最后一项
console.log(item); // pink
console.log(colors.length); // 3
```

 

- shift()

 

shift()方法用于删除数组的第一项,同时减少数组的`length` 值,返回被删除的项。

 

```js
let colors = ["red", "green", "blue", "pink"];
let item = colors.shift(); // 取得第一项
console.log(item) // red
console.log(colors.length) // 3
```

 

- splice()

 

传入两个参数,分别是开始位置,删除元素的数量,**返回包含删除元素的数组**.

 

```js
// 4 删除从第一个位置到第二个位置的数据,中间2个数据
let fruit = ["apple", "banana", "pear"];
let removed = fruit.splice(1, fruit.length - 1, "a", "b");
console.log(fruit); // ["apple", "a", "b"]
console.log(removed); // ["banana", "pear"]

 

// 5 删除数据
let fruit = ["apple", "banana", "pear"];
let removed = fruit.splice(0, fruit.length, "a", "b");
console.log(fruit); // ["a", "b"]
console.log(removed); // ["apple", "banana", "pear"]

 

// 6 删除元素
let fruit = ["apple", "banana", "pear"];
let removed = fruit.splice(0, 1);
console.log(fruit); // ["banana", "pear"]
console.log(removed); // ["apple"]
```

 

- slice()

 

slice()用于创建一个包含原有数组中一个或多个元素的新数组,不会影响原始数组。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
let colors2 = colors.slice(1); // ["orange", "yellow", "green", "cyan", "blue", "purple"] 切片:[第一个, 最后)
let colors3 = colors.slice(1, 4); // ["orange", "yellow", "green"] 切片:[第一个, 第4个)
```

 

## 改

 

即修改原来数组的内容, 常用 splice。

 

```js
// 7 第0个位置的 apple 改成 peach
let fruit = ["apple", "banana", "pear"];
let updated = fruit.splice(0, 1, "peach");
console.log(fruit); // ["peach", "banana", "pear"]
console.log(updated); // ["apple"]
```

 

## 查

 

即查找元素,返回元素坐标或者元素值。

 

- indexOf()

 

返回要查找的元素在数组中的位置,如果没有找到则返回-1。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
colors.indexOf("yellow"); // 2
```

 

- includes()

 

返回要查找的元素在数组中的位置,找到返回true,否则false。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
colors.includes("red"); // true
```

 

- find()

 

返回第一个匹配的元素。

 

```js
let colors = [
{color: "red", name: "a"},
{color: "orange", name: "b"},
{color: "yellow", name: "c"},
{color: "green", name: "d"},
{color: "cyan", name: "e"},
{color: "blue", name: "f"},
{color: "purple", name: "g"}
];
colors.find((element, index, array) => element.color === "cyan"); // {color: "cyan", name: "e"}
```

 

## 排序

 

数组有两个方法可以用来对元素重新排序:reverse 和 sort 。

 

- reverse()

 

顾明思议,将数组元素方向排列。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
colors.reverse();
console.log(colors); // ["purple", "blue", "cyan", "green", "yellow", "orange", "red"]
```

 

- sort()

 

sort()方法接受一个比较函数,用于判断哪个值应该排在前面。

 

```js
// 1 字母
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
colors.sort();
console.log(colors); // ["blue", "cyan", "green", "orange", "purple", "red", "yellow"]

 

// 2 数字比较
let numbers = [12, 23, 1, 2, 3, 4, 5, 6, 8, 8, 99, 54, 789, 33, 1, 22, 0];
numbers.sort();
console.log(numbers); // [0, 1, 1, 12, 2, 22, 23, 3, 33, 4, 5, 54, 6, 789, 8, 8, 99]
numbers.sort((a, b) => a - b);
console.log(numbers); // [0, 1, 1, 2, 3, 4, 5, 6, 8, 8, 12, 22, 23, 33, 54, 99, 789]
```

 

## 转换方法

 

常见的转换方法有:join。

 

- join()

 

join() 方法接收一个参数,即字符串分隔符,返回包含所有项的字符串。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
console.log(colors.join("、")); // red、orange、yellow、green、cyan、blue、purple
console.log("《" + colors.join("》《") + "》"); // 《red》《orange》《yellow》《green》《cyan》《blue》《purple》
```

 

## 迭代方法

 

常用来迭代数组的方法(都不改变原数组)有如下:

 

1. some()
2. every()
3. forEach()
4. filter()
5. map()
6. reduce()

 

### some()

 

对数组每一项都运行传入的函数,如果有一项函数返回true,则这个方法返回true。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan", "blue", "purple"];
let someResult = colors.some((item, index, array) => item.includes("e"));
let someResult2 = colors.some((item, index, array) => {
console.log(item);
return item.includes("ell1");
});
console.log(someResult, someResult2); // true false
```

 

### every()

 

对数组每一项都运行传入的函数,如果对每一项函数都返回 true ,则这个方法返回 true。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan-e", "blue", "purple"];
let someResult = colors.every((item, index, array) => item.includes("e"));
let someResult2 = colors.every((item, index, array) => {
console.log(item);
return item.includes("ell1");
});
console.log(someResult, someResult2); // true false
```

 

### forEach()

 

对数组每一项都运行传入的函数,没有返回值。

 

```js
let colors = ["red", "orange", "yellow", "green", "cyan-e", "blue", "purple"];
let colors2 = [];
colors.forEach((item, index, array) => {
colors2.push(item + index);
});
console.log(colors2);
/*
['red0', 'orange1', 'yellow2', 'green3', 'cyan-e4', 'blue5', 'purple6']
*/
```

 

### filter

 

对数组每一项都运行传入的函数,函数返回 true 的项会组成数组之后返回。

 

```js
let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let filterResult = numbers.filter((item, index, array) => item > 2);
console.log(filterResult); //  [3, 4, 5, 4, 3]
```

 

### map()

 

对数组每一项都运行传入的函数,返回由每次函数调用的结果构成的数组。

 

```js
let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let filterResult = numbers.map((item, index, array) => item * 2);
console.log(filterResult); // [2, 4, 6, 8, 10, 8, 6, 4, 2]
```

 

### reduce()

 

累加器。

 

```js
let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let addResult = numbers.reduce((prev, next, index, array) => {
return prev + next;
}, 100);
console.log(addResult); // 125
```

 

posted @ 2021-03-08 18:15  SkyTeam_LBM  阅读(102)  评论(0编辑  收藏  举报