javascript数组需要注意的点

Array.prototype.map()

map() 方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。

map 方法会给原数组中的每个元素都按顺序调用一次 callback 函数。callback 每次执行后的返回值组合起来形成一个新数组。 callback 函数只会在有值的索引上被调用;那些从来没被赋过值或者使用 delete 删除的索引则不会被调用。

callback 函数会被自动传入三个参数:数组元素,元素索引,原数组本身。

如果 thisArg 参数有值,则每次 callback 函数被调用的时候,this 都会指向 thisArg 参数上的这个对象。如果省略了 thisArg 参数,或者赋值为 null 或 undefined,则 this 指向全局对象 。

map 不修改调用它的原数组本身(当然可以在 callback 执行时改变原数组)。

使用 map 方法处理数组时,数组元素的范围是在 callback 方法第一次调用之前就已经确定了。在 map 方法执行的过程中:原数组中新增加的元素将不会被 callback 访问到;若已经存在的元素被改变或删除了,则它们的传递到 callback 的值是 map 方法遍历到它们的那一时刻的值;而被删除的元素将不会被访问到。

var numbers = [1, 4, 9];
var roots = numbers.map(Math.sqrt);
/* roots的值为[1, 2, 3], numbers的值仍为[1, 4, 9] */

数组遍历

使用for…in循环,可以遍历数组的所有元素。

var a = [1, 2, 3];

for (var i in a) {
    console.log(a[i]);
}

需要注意的是,for…in会遍历数组所有的键,即使是非数字键。
// for循环
var a = [1, 2, 3];
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++;
}

var l = a.length;
while (l--) {
  console.log(a[l]);
}
//foreach
var colors = ['red', 'green', 'blue'];
colors.forEach(function(color) {
  console.log(color);
});

当数组的某个位置是空元素,即两个逗号之间没有任何值,我们称该数组存在空位(hole)
数组的空位是可以读取的,返回undefined。
使用delete命令删除一个值,会形成空位。delete命令不影响length属性。
所以,使用length属性进行数组遍历,一定要非常小心。

数组的某个位置是空位,与某个位置是undefined,是不一样的。如果是空位,使用数组的forEach方法、for…in结构、以及Object.keys方法进行遍历,空位都会被跳过。
如果某个位置是undefined,遍历的时候就不会被跳过。

js 函数参数

arguments对象的长度是由传入参数的个数决定的,所以在里面打印arguments.length=1,跟形参完全没关系。
但是没有传递值的命名参数(形参)会被自动赋予undefined值,跟定义了变量没初始化一样,所以undefined值是undefined。

而且arguments的值会自动反应到形参中,所以修改arguments[0],也就修改了window。但是arguments和形参并不是用一块内存,他们只是值的同步。

但是这时候设置arguments[1]也不会修改undefined的值。因为arguments的长度只有1

所以为什么jquery源码的匿名函数有两个形参(window,undefined),传入的实参只有一个window
因为在 自调用匿名函数 的作用域内,确保undefined是真的未定义。防止undefined能够被重写,赋予新的值。