原文:https://www.w3school.com.cn/js/js_array_methods.asp

JavaScript 数组的力量隐藏在数组方法中。
**

把数组转换为字符串

toString()

JavaScript 方法 toString() 把数组转换为数组值(逗号分隔)的字符串。

  1. var fruits = ["Banana", "Orange", "Apple", "Mango"];
  2. document.getElementById("demo").innerHTML = fruits.toString();

结果

  1. Banana,Orange,Apple,Mango

join()

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

var fruits = ["Banana", "Orange","Apple", "Mango"];
document.getElementById("demo").innerHTML = fruits.join(" * ");

结果

Banana * Orange * Apple * Mango

一、把数组转换为字符串

1.1、toString()

JavaScript 方法 toString() 把数组转换为数组值(逗号分隔)的字符串。
toString() 方法以逗号分隔的字符串返回数组:
Banana,Orange,Apple,Mango


1.2、join()

join() 方法也可将所有数组元素结合为一个字符串。 它的行为类似 toString(),但是您还可以规定分隔符:
join() 方法将数组元素连接成一个字符串。
在这个例子中我们使用“”作为元素之间的分隔符:
Banana
Orange Apple Mango


二、在数组中删除与新增元素

2.1、Pop 删除元素

从数组弹出项目

2.1.1、删除元素

pop() 方法从数组中删除最后一个元素。
Banana,Orange,Apple,Mango
Banana,Orange,Apple

2.1.2、删除+返回已删元素

pop() 方法从数组中删除最后一个元素。
pop() 方法的返回值是已删除的项目。
原始数组:Banana,Orange,Apple,Mango
要删除元素:Mango
删除后数组:Banana,Orange,Apple


2.2、Push 添加新元素

向数组推入项目
push() 方法将新元素追加到数组中。
试一试
Banana,Orange,Apple,Mango

2.3、length 添加新元素

length 属性提供了向数组追加新元素的简易方法
length 属性提供了一种在不使用 push() 方法的情况下将新元素附加到数组的简便方法。
试一试
Banana,Orange,Apple,Mango

三、位移元素

3.1、shift()

位移与弹出等同,但处理首个元素而不是最后一个。shift() 方法会删除首个数组元素,并把所有其他元素“位移”到更低的索引。
shift() 方法删除数组的第一个元素(并将所有其他元素“移位”到左侧):
Banana,Orange,Apple,Mango
Orange,Apple,Mango
Orange

3.2、unshift()

3.2.1、unshift() 方法(在开头)向数组添加新元素,并“反向位移”旧元素:

unshift() 方法将新元素添加到数组的开头。
试一试
Banana,Orange,Apple,Mango

3.2.2、unshift() 方法返回新数组的长度。

unshift() 方法返回新数组的长度:
Banana,Orange,Apple,Mango
5
Lemon1,Banana,Orange,Apple,Mango
6
注释:unshift() 方法在 Internet Explorer 8 及更早版本中无法正常工作,会插入值,但返回值将是 undefined

四、更改元素

4.1、使用索引号访问数组元素fruits[]

通过使用它们的索引号来访问数组元素:
数组索引(下标)以 0 开始。[0] 是第一个数组元素,[1] 是第二个,[2] 是第三个 …
原始数组:Banana,Orange,Apple,Mango
指定元素后,新的数组:Lemon,Orange,Apple,Mango

五、删除元素 delete

既然 JavaScript 数组属于对象,其中的元素就可以使用 JavaScript delete 运算符来删除:
删除元素会在数组中留下未定义的孔。
第一种水果是:Banana
第一种水果是:undefined
使用 delete 会在数组留下未定义的空洞。请使用 pop() 或 shift() 取而代之。

六、拼接数组 splice()

6.1、新增元素

splice() 方法可用于向数组添加新项:
splice() 方法将新元素添加到数组中。
试一试
原数组:
Banana,Orange,Apple,Mango
以下是补充说明
第一个参数(2)定义了应添加新元素的位置(拼接)。
第二个参数(0)定义应删除多少元素。
其余参数(“Lemon”,“Kiwi”)定义要添加的新元素。
splice() 方法返回一个包含已删除项的数组:

6.2、新增+删除元素

以下是第二个案例,增加第二个值
原数组:
Banana,Orange,Apple,Mango

6.3、删除元素

通过聪明的参数设定,您能够使用 splice() 在数组中不留“空洞”的情况下移除元素:试一试
Banana,Orange,Apple,Mango
提示

  • 第一个参数(0)定义新元素应该被添加(接入)的位置。
  • 第二个参数(1)定义应该删除多个元素。
  • 其余参数被省略。没有新元素将被添加。

七、合并(连接)数组 concat()

concat() 方法通过合并(连接)现有数组来创建一个新数组:

7.1、实例(合并两个数组)

var myGirls = ["Cecilie", "Lone"];
var myBoys = ["Emil", "Tobias", "Linus"];
var myChildren = myGirls.concat(myBoys);   // 连接 myGirls 和 myBoys

concat() 方法不会更改现有数组。它总是返回一个新数组。
concat() 方法可以使用任意数量的数组参数:
image.png

7.2、实例(合并三个数组)

var arr1 = ["Cecilie", "Lone"];
var arr2 = ["Emil", "Tobias", "Linus"];
var arr3 = ["Robin", "Morgan"];
var myChildren = arr1.concat(arr2, arr3);   // 将arr1、arr2 与 arr3 连接在一起

image.png

7.3、实例(将数组与值合并)

concat() 方法也可以将值作为参数:

var arr1 = ["Cecilie", "Lone"];
var myChildren = arr1.concat(["Emil", "Tobias", "Linus"]);

image.png

八、裁剪数组

8.1、单个参数

slice() 方法用数组的某个片段切出新数组。
本例从数组元素 1 (”Orange”)开始切出一段数组:

var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1);  // Orange,Lemon,Apple,Mango

image.png

8.2、两个参数

slice() 可接受两个参数,比如 (1, 3)。
该方法会从开始参数选取元素,直到结束参数(不包括)为止。

var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"];
var citrus = fruits.slice(1, 3);

image.png

如果结束参数被省略,比如第一个例子,则 slice() 会切出数组的剩余部分。

九、自动 toString()

如果需要原始值,则 JavaScript 会自动把数组转换为字符串。下面两个例子将产生相同的结果:

var fruits = ["Banana", "Orange", "Apple", "Mango"];
document.getElementById("demo").innerHTML = fruits.toString();

image.png

var fruits = ["Banana", "Orange", "Apple", "Mango"];
document.getElementById("demo").innerHTML = fruits;

image.png

所有 JavaScript 对象都拥有 toString() 方法。
我们可以看到上述两个例子的值是相同的。

参考手册

如需完整的参考手册,请访问我们完整的 JavaScript 数组参考手册
该参考手册包含所有数组属性和方法的描述和实例。