JavaScript数组
JavaScript数组用于在一个变量中存储多个值,并且可以通过使用索引来访问这些值。
创建数组
有两种创建数组的方式
- 使用数组文本创建
var arrayName=[value1,value2,value3...];
其中的空格和折行无所谓,声明可以跨行。注意最后一个元素后面不要写逗号就行。
- 使用关键字new创建
var arrayName=new Array(value1,value2,value3...);
上面两个效果一样,出于简洁、可读性和执行速度的考虑,应该使用前面一种方法。
访问数组
可以使用下标来访问数组元素,和C/C++一样,可以这样来修改数组。不同的有,如果想要访问完整数组,可以通过引用数组名来访问完整数组。
数组是一种特殊类型的对象,对数组使用typeof运算符,将会返回object
数组元素可以是数字可以是字符可以是字符串、可以是对象、甚至可以是数组是函数。
数组的属性和方法
类别 | 表示 | 作用 |
---|---|---|
属性 | length | 返回数组的元素数目 |
函数 | forEach() | 函数接收一个函数作为参数,将数组中每一个元素作为参数传递给作为参数的函数 |
方法 | push() | 用于向数组末尾添加元素-此方法接受的参数 |
更多数组方法请看这里 |
也可以使用
length属性添加元素,这一点比C/C++高级,这样不会溢出,但是如果直接使用比数组大小大的索引添加数组元素,那么将在数组中创建未定义的洞,他们的值都是
undefined
关联数组
具有命名索引的数组称为关联数组(或者叫做散列)
JavaScript中不支持散列,只能够使用数字索引。假如使用命名索引,JavaScript 会把数组重定义为标准对象,所有数组的方法和属性将产生非正确结果。在JavaScript中,数组使用数字索引,对象使用命名索引。
判断是否为数组的三种方法
方法 | 描述 |
---|---|
Array.isArray() | 如果是数组则返回真 这个是ECMAScript 5定义的新方法,不支持老的浏览器 |
自定义isArray()函数 | 下面表示如果对象的原型包含单词"Array"那么返回真 |
instanceof运算符 | 如果对象是由给定的构造器创建,返回true |
数组方法
方法 | 描述 | 跳转 |
---|---|---|
toString() | 把数组转换为数组值,中间用逗号分开 所有JavaScript对象都有这个方法 | 1 |
join() | 类似于上者,可以将数组组合成字符串,但是还可以指定分隔符 | 2 |
pop() | 删除数组最后一个元素,并返回这个值 | 3 |
push() | 向数组尾添加一个新元素,并返回新数组的长度 | |
shift() | 将数组向左位移一个单位,即删除数组的首个元素,返回被删除的值 | 4 |
unshift() | 将数组向右位移一个单位,即空出来了第一个元素,即在数组头添加元素,返回新数组的长度 | |
delete运算符 | 删除数组中某个元素,对应元素将变为undefined,留下空洞 | 5 |
splice() | 第一个参数指定插入的位置,将在指定位置之前插入元素,第二个参数指定删除元素的个数,其余参数表示添加进去的元素,此方法返回将删除项作为元素的数组。通过合理的设置参数值,可以不留空洞的删除数组元素。 | 6 |
concat() | 可以接收多个数组作为参数,也可以将多个值作为参数,追加到调用的数组后面,形成一个新的数组,这种方法创建一个新的数组而不改变已有的数组。 | 7 |
slice() | 可以只使用一个参数表示从这个位置开始选取出剩下的片段成为一个新数组,或者接受两个参数,表示选区的区间(左闭右开),这个方法不改变原来的数组,返回一个新的数组 | 8 |
1
2
3
4
5
6
7
8