JavaScript Good Parts学习笔记-数组篇

数组是一段线性分配的内存。通过计算偏移来访问其中的元素。

不幸的是,JavaScript并没有像数组一样的数据结构

作为替代,JavaScript提供了类数组的对象,把数组下标改为字符串。

1 数组字面量(Array Literals)---继承自Array.prototype,所以继承了大量有用的方法,比如length属性

var empty = [];
var numbers = [
    'zero', 'one', 'two', 'three', 'four',
    'five', 'six', 'seven', 'eight', 'nine'
];
empty[1] // undefined
numbers[1] // 'one'
empty.length // 0
numbers.length // 10

对象字面量---继承自Object.prototype

var numbers_object = {
    '0': 'zero',
    '1': 'one',
    '2': 'two',
    '3': 'three',
    '4': 'four',
    '5': 'five',
    '6': 'six',
    '7': 'seven',
    '8': 'eight',
    '9': 'nine'
};

注:在大多数语言中,数组对象要求里面元素类型一致,但是JavaScript不是这样的。

2 长度(length)

和大多数语言不同,JavaScript的数组length是没有上界的,如果用大于当前length的下标存储,不会出错,

数组会被自动扩容。

 

3 删除(Delete)

因为JavaScript的数组就是对象,所以可以用delete运算符从数组中删除对象

delete numbers[2];
// numbers is ['zero', 'one', undefined, 'shi', 'go']

这样删除后,会在原来的位置留下个“空洞”

所以正确的删除应该是用splice方法 第一个参数是数组中序号,第二个参数是删除的个数

numbers.splice(2, 1);
// numbers is ['zero', 'one', 'shi', 'go']

注:对于大型数组来说,效率会不高。

4 枚举(Enumeration)

注意,for in 无法保证顺序,而且可能取得原型链上的属性,所以不推荐使用。

常规的for没有问题。代码如下

var i;
for (i = 0; i < myArray.length; i += 1) {
document.writeln(myArray[i]);
}

 

5 容易混淆的地方(Confusion)

常见的错误是数组和对象混用。

规则其实很简单,当属性名是小而连续的整数时,使用数组,否则就使用对象。

可以用下面的方法判断是否数组

var is_array = function (value) {
return Object.prototype.toString.apply(value) === '[object Array]';
};

 

6 方法(Methods)

JavaScript提供了一套数组可用的方法,是储存在Array.prototype中的函数

我们可以扩充他,比如增加一个对数组进行计算的方法

Array.prototype.reduce = function(f, value) {
    var i;
    for (i = 0; i < this.length; i += 1) {
        value = f(this[i], value);
    }
    return value;
};

使用这个方法的例子。

// Create an array of numbers.
var data = [4, 8, 15, 16, 23, 42];
// Define two simple functions. One will add two
// numbers. The other will multiply two numbers.
var add = function(a, b) {
    return a + b;
};
var mult = function(a, b) {
    return a * b;
};
// Invoke the data's reduce method, passing in the
// add function.
var sum = data.reduce(add, 0); // sum is 108
// Invoke the reduce method again, this time passing
// in the multiply function.
var product = data.reduce(mult, 1);
// product is 7418880

7 指定初始值(Dimensions)

Array.dim = function (dimension, initial) {
var a = [], i;
for (i = 0; i < dimension; i += 1) {
a[i] = initial;
}
return a;
};
// Make an array containing 10 zeros.
var myArray = Array.dim(10, 0);

posted on 2017-02-15 11:35  sdfczyx  阅读(184)  评论(0编辑  收藏  举报