一、数组
数组(Array)是属于内置对象,我们可以在MDN网站上查询各种方法。
数组和普通对象的功能类似,也是用来存储一些值的。不同的是:
普通对象是使用字符串作为属性名的,而数组是使用数字来作为索引来操作元素。索引:从0开始的整数就是索引。
数组的存储性能比普通对象要好。在实际开发中我们经常使用数组来存储一些数据,使用频率非常高。
二、数组的基本操作
数组的元素可以是任意的数据类型,也可以是对象,也可以是函数,也可以是数组。类型和长度都没有限制。
数组的元素中,如果存放的是数组,我们就称这种数组为二维数组。
1、创建数组对象
方法一:字面量创建。
var arr = [1,2,3]
方法二:利用对象创建
var arr = new Array(参数);
如果参数为空,则表示创建一个空数组;参数位置是一个数值时,表示数组长度;参数位置是多个数值时,表示数组中的元素。
var arr1 = new Array(); // 参数为空
var arr2 = new Array(4); // 参数为一个数值
var arr3 = new Array(15, 16, 17); // 参数为多个数值
console.log(typeof arr1); // 输出结果:object
console.log("arr1 = " + arr1);
console.log("arr2 = " + arr2);
console.log("arr3 = " + arr3);
2、像数组中添加元素
语法:数组[索引] = 值
var arr1 = [];
// 向数组中添加元素
arr[0] = 10;
arr[1] = 33;
arr[2] = 22;
arr[3] = 44;
3、获取数组中的元素
语法:数组[索引]
数组的索引代表的是数组中的元素在数组中的位置,从0开始。
如果读取不存在的索引(比如元素没那么多),系统不会报错,而是返回undefined。
var arr = [21, 22, 23];
console.log(arr[0]); // 输出结果:21
console.log(arr[5]); // 输出结果:undefined
4、获取数组的长度
语法:数组的长度 = 数组.length
var arr = [21, 22, 23];
console.log(arr.length); // 输出结果:3
注:对于连续的数组,使用length可以获取到数组的长度(元素的个数);对于非连续的数组,使用length会获取到数组的最大的索引+1。因此,尽量不要创建非连续的数组。
5、修改数组的长度
-
如果修改的length大于原长度,则多出部分会空出来,置为 null。
-
如果修改的length小于原长度,则多出的元素会被删除,数组将从后面删除元素。
特例:伪数组arguments的长度可以修改,但是不能修改里面的元素,后续会进行补充。。。。
var arr1 = [11, 12, 13];
var arr2 = [21, 22, 23];
// 修改数组 arr1 的 length
arr1.length = 1;
console.log(JSON.stringify(arr1)); //输出为[11]
// 修改数组 arr2 的 length
arr2.length = 5;
console.log(JSON.stringify(arr2)); //输出为[21,22,23,null,null]
三、数组的常用方法
基本方法
方法 | 描述 | 备注 |
---|---|---|
push() | 向数组的最后面插入一个或多个元素,返回结果为该数组新的长度 | 会改变原数组 |
pop() | 删除数组中的最后一个元素,返回结果为被删除的元素 | 会改变原数组 |
unshift() | 在数组最前面插入一个或多个元素,返回结果为该数组新的长度 | 会改变原数组 |
shift() | 删除数组中的第一个元素,返回结果为被删除的元素 | 会改变原数组 |
1、push():在数组的最后面插入一个或多个元素,返回结果为该数组的长度。
语法:
数组的新长度 = 数组.push(元素);
var arr = ["周震南", "姚琛", "张颜齐"];
var result1 = arr.push("刘也"); // 末尾插入一个元素
var result2 = arr.push("任豪", "赵让"); // 末尾插入多个元素
console.log(result1); // 输出结果:4
console.log(result2); // 输出结果:6
console.log(JSON.stringify(arr)); // 输出结果:["周震南", "姚琛", "张颜齐","刘也","任豪", "赵让"]
2、pop():删除数组中的最后一个元素,返回结果为被删除的元素
语法:
被删除的元素 = 数组.pop();
var arr = ["周震南", "姚琛", "张颜齐"];
var result1 = arr.pop();
console.log(result1); // 输出结果:张颜齐
console.log(JSON.stringify(arr)); // 打印结果:["周震南", "姚琛"]
3、unshift():在数组最前面插入一个或多个元素,返回结果为该数组新的长度。插入元素后,其他元素的索引会依次调整。
语法:
数组的新长度 = 数组.unshift(元素);
var arr = ["周震南", "姚琛", "张颜齐"];
var result1 = arr.unshift("刘也"); // 最前面插入一个元素
var result2 = arr.unshift("任豪", "赵让"); // 最前面插入多个元素
console.log(result1); // 输出结果:4
console.log(result2);