数组
数组的概念
数组是指一组数据的集合,其中的每个数据被称作元素,在数组中可以存放任意类型的元素,数组是一种将一组数据存储在单个变量名下的优雅方式
// 普通变量一次只能存储一个值
var num = 10;
// 数组一次可以存储多个值
var arr = [1,2,3,4,5];
创建数组
数组的创建方式
JS 中创建数组有两种方式:
- 利用 new 创建数组
- 利用数组字面量创建数组
利用 new 创建数组
var 数组名 = new Array();
var arr = new Array(); // 创建一个新的空数组
var arr = new Array(2); // 这个2 表示 数组的长度为 2 里面有2个空的数组元素
var arr = new Array(2, 3); // 等价于 [2,3] 这样写表示 里面有2个数组元素 是 2和3
- 注意 Array(),A 要大写
利用数组字面量创建数组
// 1. 使用数组字面量方式创建空的数组
var 数组名 = [];
// 2. 使用数组字面量方式创建带初始值的数组
var 数组名 = ['小白','小黑','大黄','瑞奇'];
- 数组的字面量是方括号[]
- 声明数组并赋值称为数组的初始化
- 这种字面量方式也是我们以后最多使用的方式
数组元素的类型
数组中可以存放任意类型的数据,例如字符串,数字,布尔值等
var arrStus = ['小白',12,true,28.9];
获取数组元素
数组的索引
==索引 (下标) :==用来访问数组元素的序号 ( 数组下标从0开始 )
var arr = ['小白','小黑','大黄','瑞奇'];
索引号 : 0 1 2 3
数组可以通过索引来访问、设置、修改对应的数组元素,我们可以通过 “数组名[索引]” 的形式来获取数组中的元素
这里的访问就是获取得到的意思
// 定义数组
var arrStussy = [1,2,3];
// 获取数组中的第2个元素
alert(arrStus[1]); // 2
数组的长度
使用 “数组名.length” 可以访问数组元素的数量(数组长度)
- 数组的长度是元素个数 不要跟索引号混淆
- 数组名.leng 是动态检测数组元素的个数
还可以代替从 0 开始的变量
遍历数组
遍历数组:就是把数组的元素从头到尾访问一次
从数组中取出每一个元素时,代码是重复的,有所不一样的是索引值在递增,可以用循环来遍历数组
// 这里常用 for 循环来遍历数组
var arr = [1,2,3];
for (var i = 0; i < arr.length; i++) {
console.log(arr[i]);
}
- 因为我们的数组索引号从0开始,所以 i 必须从0开始 i < arr.length 小于数组的长度
- 输出的时候 arr[i] i 计算器当索引号来用
数组中新增元素
可以通过修改length长度 以及 索引号增加数组元素
通过修改 length 长度新增数组元素
- 可以通过修改 length 长度来实现数组扩容的目的
- length 属性是可读写的
var arr = ['red','green','blue','pink'];
arr.length = 7;
console.log(arr);
console.log(arr[4]); // undefined
console.log(arr[5]); // undefined
console.log(arr[6]); // undefined
其中索引号是4,5,6的空间没有给值,就是声明变量未给值,默认值就是 undefined
通过修改数组索引的方式追加数组元素
- 可以通过修改数组索引的方式追加数组元素
- 不能直接给数组名赋值,否则会覆盖掉以前的数据
var arr = ['red','green','blue','pink'];
arr[4] = 'hotpink';
console.log(arr);
这种方式也是我们最常用的一种方式