前端学习(39)~js学习(十六):数组
数组简介
数组(Array)是属于内置对象,我们可以在MDN网站上查询各种方法。
数组和普通对象的功能类似,也是用来存储一些值的。不同的是:
- 普通对象是使用字符串作为属性名的,而数组是使用数字来作为索引来操作元素。索引:从0开始的整数就是索引。
数组的存储性能比普通对象要好。在实际开发中我们经常使用数组来存储一些数据,使用频率非常高。
数组中的元素可以是任意的数据类型,也可以是对象,也可以是函数,也可以是数组。数组的元素中,如果存放的是数组,我们就称这种数组为二维数组。
接下来,我们讲一讲数组的基本操作。
创建数组对象
方式一:使用数组字面量创建数组
举例:
var arr1 = []; // 创建一个空的数组 var arr2 = [1,2,3]; // 创建带初始值的数组
方式一最简单,也用得最多。
方式二:使用构造函数创建数组
语法:
var arr = new Array(参数);
如果参数为空,则表示创建一个空数组;如果参数是一个数值时,表示数组的长度;参数位置是多个数值时,表示数组中的元素。
来举个例子:
// 方式一 var arr1 = [11, 12, 13]; // 方式二 var arr2 = new Array(); // 参数为空 var arr3 = new Array(4); // 参数为一个数值 var arr4 = new Array(15, 16, 17); // 参数为多个数值 console.log(typeof arr1); // 打印结果:object console.log("arr1 = " + JSON.stringify(arr1)); console.log("arr2 = " + JSON.stringify(arr2)); console.log("arr3 = " + JSON.stringify(arr3)); console.log("arr4 = " + JSON.stringify(arr4));
打印结果:
object arr1 = [11,12,13] arr2 = [] arr3 = [null,null,null,null] arr4 = [15,16,17]
从上方打印结果的第一行里,可以看出,数组的类型其实也是属于对象。
数组中的元素的类型
数组中可以存放任意类型的数据,例如字符串、数字、布尔值、对象等。
比如:
var arr = [‘qianguyihao‘, 28, true, {name: ‘qianguyihao‘}];
数组的基本操作
数组的索引
索引 (下标) :用来访问数组元素的序号,代表的是数组中的元素在数组中的位置(下标从 0 开始算起)。
数组可以通过索引来访问、设置、修改对应的数组元素。
向数组中添加元素
语法:
数组[索引] = 值
代码举例:
var arr = []; // 向数组中添加元素 arr[0] = 10; arr[1] = 20; arr[2] = 30; arr[3] = 40; arr[5] = 50; console.log(JSON.stringify(arr));
打印结果:
[10,20,30,40,null,50]
获取数组中的元素
语法:
数组[索引]
如果读取不存在的索引(比如元素没那么多),系统不会报错,而是返回undefined。
代码举例:
var arr = [21, 22, 23]; console.log(arr[0]); // 打印结果:21 console.log(arr[5]); // 打印结果:undefined
获取数组的长度
可以使用length
属性来获取数组的长度(即“元素的个数”)。
数组的长度是元素个数,不要跟索引号混淆。
语法:
数组的长度 = 数组名.length;
代码举例:
var arr = [21, 22, 23]; console.log(arr.length); // 打印结果:3
补充:
对于连续的数组,使用length可以获取到数组的长度(元素的个数);对于非连续的数组,使用length会获取到数组的最大的索引+1。因此,尽量不要创建非连续的数组。
修改数组的长度(修改length)
如果修改的length大于原长度,则多出部分会空出来,置为 null。
如果修改的length小于原长度,则多出的元素会被删除,数组将从后面删除元素。