JavaScript学习第四天笔记(数组)
数组
概述
数组是什么
数组是值的有序集合。数组中的每个值叫做一个元素,而每个元素在数组中都右一个唯一的位置。这个位置用数字表示,叫做索引数组;用字符串表示,叫做关联数组。
JavaScript数组是无类型的;数组的元素可以是任何的类型(字符串,数字值,布尔值等),并且每个数组的不同元素可能是不同的类型。
JavaScript数组是动态的:根据需要,可以动态地向数组插入新的元素,或者从数组中删除指定的元素
一维数组
定义数组
1.使用字面量/直接量方式定义
语法:
var 数组名称 = [元素1,元素2,...]
示例代码:
var arr1 = [];/*定义一个空数组*/ var arr2 = [100,'星矢',true]; console .log(arr1);/*输出结果为:[]*/ console .log(arr2);/*输出结果:[100,'星矢',true]*/
2.构造函数方式
语法:
var 数组名称 = new Array (元素1,元素2,...); var 数组名称 = new Array (length);/*length是number类型 表示数组的长度(存在的元素个数)*/
示例代码:
var arr1 = new Array ();/*定义一个空数组*/ var arr2 = new Array (100,'星矢',true); var arr3 = new Array (length); console .log(arr1); 输出结果:[100,'星矢',true]*/ console .log(arr2); /*输出结果:*/ console .log(arr3); /*输出结果:[ <10 empty items> ]*/
3.函数方式定义
语法:
var 数组名称 = Array(元素1,元素2,元素3...); var 数组名称 = Array(length);
示例代码:
var arr1 = Array(100,5,2,);
var arr2 = Array(5);
console .log(arr1);/输出结果:[ 100, 5, 10 ]/
console .log(arr2);/输出结果:[ <50 empty items> ]/
索引数组
概述
索引数组就是存储元素的位置使用数字值来表示,一般称之为下标或角标。数组的长度与元素的个数是一致的,数字是以0开头的。
示例代码如下:
var arr = []; arr[0]='索引数组'; arr[1]=100; arr[2]=true; console .log(arr);/*输出结果为: ['索引数组',100,true]*/
关联数组
注意:关联数组的数组的长度与元素的个数不一致,原因是JavaScript的官方不支持关联数组。
var arr = [];/*定义一个空数组*/ arr['who']='谁啊' arr['what']='啥啊' arr['how']='咋的了' console .log(arr);/*输出结果:[ who: '谁啊', what: '啥啊', how: '咋的了' ]*/
稀疏数组
索引数组的位置允许不连续的,没有定义的元素的位置默认为空(undefined),这样的数组叫做稀疏数组,数组的长度与元素的个数是不一样的。
示例代码:
var arr = []; arr[0]='谁啊'; arr[5]='啥啊'; arr[6]='咋的了'; console .log(arr); console .log(arr.length);/*输出的结果为: [ '谁啊', <4 empty items>, '啥啊', '咋的了' ] 7 */
将稀疏数组进行处理,得到正常的索引数组
var newArr=[]; for (var i=0; i<arr.length; i++){ if(arr[i] !== undefined){ newArr.push(arr[i]); } } console .log(newArr);
访问数据的元素
示例代码如下:
// 定义数组的默认为索引数组 var arr = ['索引数组',100,null]; // 调用数组名称时,得到只是存储所有元素数据的集合 console.log(arr); // 访问索引数组中的元素 -> 数组名称[索引值] console.log(arr[0]); // 如果访问了数组中未定义的位置的元素时 - 语法不抱错,结果为 undefined console.log(arr[5]); // 索引数组中索引值最大为 arr.length - 1 // JavaScript中的关联数组定义与访问都是没有问题的 var arr1 = []; arr1['name'] = 'Chambers'; arr1['age'] = 23; arr1['job'] = '学生'; console.log(arr1['name']);
数组的修改
示例代码:
var arr1 = []; arr1[0] = '卧龙学苑'; arr1[1] = true; // 关联数组 var arr2 = []; arr2['name'] = '张无忌'; arr2['age'] = 19; arr2['job'] = '教主'; // 通过数组的索引值找到对应元素的位置,再通过重新赋值的操作进行修改 arr1[0] = 100; console.log(arr1); arr2['name'] = '周芷若';2176491621 console.log(arr2); // 如果索引值是新的,就是新增数组的元素操作 arr1[4] = '卧龙学苑'; console.log(arr1);
数组的删除
var arr1 = []; arr1[0] = '卧龙学苑'; arr1[1] = true; // 关联数组 var arr2 = []; arr2['name'] = '张无忌'; arr2['age'] = 19; arr2['job'] = '教主'; /* 使用 delete 运算符进行删除数组的元素 * 注意 - 只是删除元素的数据内容,而对应的位置被保留 -> 稀疏数组 */ delete arr1[0]; console.log(arr1);
循环遍历数组
var arr = ['卧龙学苑', 100, true, undefined]; for (var i=0; i<arr.length; i++) { console.log(arr[i]); }
for...in语句
在ECMAScript5中新增了for...in语句 同样可用于遍历数组
for...in语句还可以用于遍历稀疏数组 循环的每次将一个有效元素返回
for语句: 循环的开始和结束 都是由程序员决定的
for..in语句: 循环只能从开始到结束
var arr = ['卧龙学苑', 100, true, undefined]; for (var i in arr) { console.log(arr[i]); }
二维数组
什么是二维数组
数组是可以嵌套的,这就意味着数组可以作为一个元素被包含在另外一个数组里面,利用JS这个特点创建二维数组,即数组的数组。
var arr = [];// 定义一个空数组 arr[0] = [100,200,300]; arr[1] = [400,500,600]; arr[2] = [700,800,900]; // console.log(arr); // 访问二维数组中的元素 var result = arr[0]; /*console.log(result[0]); console.log(arr[0][0]);*/ // 循环遍历二维数组 for (var i=0; i<arr.length; i++) { console.log(arr[i]); for (var j=0; j<arr[i].length; j++) { console.log(arr[i][j]); } }