ECMAScript/ES6数组
JavaScript中的数组是一个对象,用于表示相似类型的元素的集合。 我们可以在一个变量名中存储多个值或一组值。 数组用于按时间顺序存储值的集合。 数组是同类元素的集合,或者说数组是相同数据类型的值的集合。
我们可以存储任何有效值,例如对象,数字,字符串,函数以及其他数组,这使得创建复杂的数据结构(如数组数组或对象数组)成为可能。
1.语法
声明数组的方法有两种:
// 声明
var myArray;
// 初始化
myArray = [val1, val2, .., valN]
// 或者
var myArray = [val1,val2, .., valN]
数组参数包含整数和字符串的列表。 建议使用数组文字来创建数组,而不要使用new
关键字。new
关键字只会使代码复杂化,有时会产生意外的结果。如果在数组的构造函数中指定单个数字参数(或使用new
关键字创建数组),则它将被视为数组的长度。
注意:数组允许的最大长度为
4,294,967,295
。
2.访问数组元素
数组从0开始索引。数组名称后跟下标用于引用数组元素。
语法:
array_name[subscript];
示例代码:
var num;
num = [2,4,6,8];
console.log(num[0]);
console.log(num[1]);
执行上面示例代码,得到以下结果:
2
4
3.数组构造器
可以使用数组构造函数创建一个数组。 数组构造函数可以通过以下方式传递:
- 值列表,以逗号分隔,或
- 一个数值,指示数组的大小
如下图解:
var myArray = [ 4, 8, 13, 6, 55, 41, 42, 99, 1 ];
console.log("Length of myArray: " + myArray.length); // 9 Elements
console.log("Element at index 0: " + myArray[0]); // 4
console.log("Element at index 1: " + myArray[1]); // 8
console.log("Element at index 4: " + myArray[4]); // 55
可以将新值分配给数组元素:
var names = [ "Trump", "Putin", 100 ];
console.log("Length of array: " + names.length); // 3 Elements
console.log("Element at index 0: " + names[0]); // Trump
console.log("Element at index 1: " + names[1]); // Putin
console.log("Element at index 2: " + names[2]); // 100
// Assign new value to element at index 2:
names[2] = "Merkel";
console.log("Element at index 2: " + names[2]);
使用循环,可以这样访问数组元素:
var fruits = ["Acerola", "Apple", "Banana", "Breadfruit", "Carambola" ];
for( var index = 0; index < fruits.length; index++) {
console.log("Index: " + index+" Element value: " + fruits[index]);
}
4.JavaScript数组
JavaScript支持以下类别的数组。
- 多维数组
- 将数组传递给函数
- 从函数返回数组
4.1.ES6多维数组
ES6还支持多维数组概念。 多维数组可以定义为对另一个数组的值的数组引用。多维数组未在JavaScript中直接提供。 如果需要创建多维数组,则需要使用一维数组来完成。
我们也可以把二维数组看作是多维数组的最简单形式。
声明
以下语法说明了如何在JavaScript中声明二维数组。
var array_name = [[value1,value2,value3],[val1,val2,val3]];
二维数组中元素的访问 -
var array_name[initial_array_index][referenced_array_index]
示例代码:
var multi = [[2,3,4],[4,9,16]]
console.log(multi[0][0])
console.log(multi[0][1])
console.log(multi[0][2])
console.log(multi[1][0])
console.log(multi[1][1])
console.log(multi[1][2])
执行上面示例代码,得到以下结果:
2
3
4
4
9
16
4.2.将数组传递给函数
将数组作为参数传递给函数时,必须指定不带括号的数组名称(对数组的引用)。
示例代码
var rainbow = new Array["Violet", "Indigo", "Blue", "Green", "Yellow", "Orange", "Red"];
function show(rainbow) {
for(var i = 0;i<rainbow.length;i++) {
console.log(rainbow[i])
}
}
show(rainbow)
执行上面示例代码,得到以下结果:
Violet
Indigo
Blue
Green
Yellow
Orange
Red
4.3.从函数返回数组
函数可以返回数组:
function show() {
return new Array("Blue", "Red", "Green", "Yellow")
}
var colors = show()
for(var i in colors) {
console.log(colors[i])
}
执行上面示例代码,得到以下结果:
Blue
Red
Green
Yellow
5.数组方法
ES6中的数组方法对于处理数组中存储的数据很有用。数组方法用于通过数组轻松执行复杂的任务。可以通过单击此链接ES6数组方法来了解有关数组方法的更多信息。
6.销毁分配
ES6提供了一个称为销毁分配的新功能,该功能能够从对象和数组中提取特定项目,并使用简写语法将它们放入变量中。它不仅有助于减少代码,而且可以改变代码的结构方式。这是销毁结构的过程。
销毁分配是一个JavaScript表达式,可以从数组,映射,集合以及不同变量的对象属性中提取数据。
7.数组解构
重构意味着将复杂的结构分解为更简单的部分。使用解构语法,可以从对象和数组中提取较小的片段。它可以用于变量的赋值和声明。
要了解有关阵列解构的更多信息,可以单击此链接ES6数组解构。
8.对象解构
它类似于数组解构,除了可以从对象中提取属性(或键)及其对应的值,而不是从数组中提取值。
要了解有关对象解构的更多信息,可以单击此链接ES6对象解构。