## 数组
**1.数组简介**
数组是值的有序集合。每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示(从0开始),称为索引,整个数组用方括号表示。
```
var arr = [1,2,3];
```
除了在定义时赋值,数组也可以先定义后赋值。
```
var arr = [];
arr[0] =1;
```
数组元素可以是任意类型。
```
var arr = [1,'a',{name:'a'},function(){}];
```
上面数组arr的4个元素分别是数字,字符串,对象,函数。
数组属于一种特殊的对象。
```
typeof [1]
// "object"
```
JavaScript语言规定,对象的键名一律为字符串,所以,数组的键名其实也是字符串。之所以可以用数值读取,是因为非字符串的键名会被转为字符串。
**2、创建数组**
**2.1 创建数组**
**(1)数组直接量**
使用数组直接量是创建数组最简单的方法,在方括号中将数组元素用逗号隔开即可。
```
var arr = [1,2,3];
```
注:如果省略数组直接量的某个值,省略的元素将被赋予undefined值。
**(2)new Array()**
我们也可以调用构造函数Array()创建数组
```
var a=new Array();
var a2=new Array(10);
var a3=new Array(1,2,3,4);
```
上面的例子,a是一个空数组,a2是一个包含10个数组项但为undefined的数组,a3是包含4个数组项,并且分别有值。
**2.2 数组长度**
每个数组都有一个**length**属性,返回数组的元素数量
```
[1,2,3].length //3
```
JavaScript使用一个32位整数,保存数组的元素个数。这意味着,数组成员最多只有4294967295个(232 - 1)个,也就是说length属性的最大值就是4294967295。
只要是数组,就一定有length属性。该属性是一个动态的值,等于键名中的最大整数加上1.
length属性是可写的。如果人为设置一个小于当前成员个数的值,该数组的成员会自动减少到length设置的值。
```
var arr = [1,2,3]
arr.length //3
arr.length = 2;
arr //[1,2]
```
将数组清空的一个有效方法,就是将length属性设为0。
```
var arr = [1,2,3];
arr.length = 0;
arr //[]
```
如果人为设置length大于当前元素个数,则数组的成员数量会增加到这个值,新增的位置都是空位。
```
var arr = [1];
arr.length=3;
arr[1] //undefined
```
在ECMAScript 5中,可以用Object.defineProperty() 让数组的length属性变成只读。
**2.3 空位**
当数组的某个位置是空元素,即两个逗号之间没有任何值,我们称该数组存在空位(hole)。
```
var arr = [1,,2]
arr.length //3
```
但是,如果最后一个元素后面有逗号,并不会产生空位。数组直接量的语法允许有可选的结尾的逗号,故[,,]只有两个元素而非三个。
```
var arr = [,,];
arr.length //2
```
**2.4 数组元素的读和写**
使用([])操作符来访问数组中的一个元素。
```
var arr = [1,2]
arr[0] //1
arr[1]=3; // [1,3]
```
**2.5 数组元素的添加和删除**
可以使用push()方法在数组末尾添加一个或多个元素。
```
var arr = [1,2]
arr.push(3) // [1,2,3]
arr.push('a','b') //[1,2,3,'a','b']
// shift()是删除数组的一个元素。
arr.shift() // [2,3,'a','b']
```
**2.6 稀疏数组**
稀疏数组是指包含从0开始的不连续索引的数组。通常,数组的length属性值代表数组中元素的个数,但如果是稀疏数组,length属性值大于元素的个数。
**2.7 多维数组**
JavaScript不支持真正的多维数组,但可以用数组的数组来近似。也可以说,数组里放数组。
```
var arr = [[1],[2,3]];
arr[0][0] // 1
arr[1][1] //3
```
**2.8 遍历数组**
我们可以使用for循环、while循环、for..in或者forEach()方法来遍历数组
```
var a = [1, 2, 3];
// for循环
for(var i = 0; i < a.length; i++) {
console.log(a[i]);
}
//while
var i = 0;
while (i < a.length) {
console.log(a[i]);
i++;
}
//for..in
for (var i in a) {
console.log(a[i]);
}
//forEach
a.forEach(function(v){
console.log(v);
})
```
**2.9 类数组对象**
在JavaScript中,有些对象被称为“类数组对象”。意思是,它们看上去很像数组,可以使用length属性,但是它们并不是数组,无法使用一些数组的方法。
```
var o = {
0: 'a',
1: 'b',
length:2
}
o[0] // "a"
o[1] // "b"
o.length // 2
o.push('d') // TypeError: o.push is not a function
```
上面代码中,变量o是一个对象,虽然使用的时候看上去跟数组很像,但是无法使用数组的方法。这就是类数组对象。
`类数组对象`有一个特征,就是具有length属性。换句话说,只要有length属性,就可以认为这个对象类似于数组。但是,对象的length属性不是动态值,不会随着成员的变化而变化。
由于类数组对象没有继承自Array.prototype,那就不能在它们上面直接调用数组方法。不过我们可以间接的使用Function.call方法调用。
```
var o = {
0: 'a',
1: 'b',
length:2
};
Array.prototype.slice.call(o) // ["a","b"]
```
典型的类似数组的对象是函数的arguments对象,以及大多数DOM元素集,还有字符串。
- 前言
- JavaScript简介
- 基本概念
- 语法
- 数据类型
- 运算符
- 表达式
- 语句
- 对象
- 数组
- 函数
- 引用类型(对象)
- Object对象
- Array对象
- Date对象
- RegExp对象
- 基本包装类型(Boolean、Number、String)
- 单体内置对象(Global、Math)
- console对象
- DOM
- DOM-属性和CSS
- BOM
- Event 事件
- 正则表达式
- JSON
- AJAX
- 表单和富文本编辑器
- 表单
- 富文本编辑器
- canvas
- 离线应用
- 客户端存储(Cookie、Storage、IndexedDB)
- HTML5 API
- Video/Audio
- Geolocation API
- requestAnimationFrame
- File API
- FullScreen API
- IndexedDB
- 检测设备方向
- Blob
- vibrate
- Luminosity API
- WebRTC
- Page Visibility API
- Performance API
- Web Speech
- Notification
- 面向对象的程序设计
- 概述
- this关键字
- 原型链
- 作用域
- 常用API合集
- SVG
- 错误处理机制
- JavaScript开发技巧合集
- 编程风格
- 垃圾回收机制