伪数组
伪数组的本质是个对象,它拥有数组三要素:元素、下标、长度,但不能调用数组api
一个伪数组的范例:
//伪数组
var nameArr = {
0:'lin',
1:'wang',
2:'Steven',
3:'taku',
length:4
};
console.log(nameArr.length);//4
console.log(nameArr[2]);//Steven
伪数组转数组
//伪数组转数组-1
var newArr = [];
newArr.push.apply(newArr,nameArr);
console.log(newArr);//["lin", "wang", "Steven", "taku"]
//伪数组转数组-2
var newArr = [];
newArr = newArr.concat.apply(newArr,nameArr);
console.log(newArr);//["lin", "wang", "Steven", "taku"]
//伪数组转数组-3
var newArr = Array.prototype.slice.call(nameArr,0);
console.log(newArr);//["lin", "wang", "Steven", "taku"]
apply上下文方法,第一个参数指定this指向,第二个参数指定参数。通过apply方法将伪数组每一个元素作为实参
方法三调用了数组原型的slice方法,选取call()得到的数组参数
修改this指向的方法:apply(),call(),bind()
apply() | 函数名.apply(this修改后的指向,伪数组或数组) |
call() | 函数名.call(this修改后的指向,一个或多个的参数) |
bind() | 函数名.bind(this修改后的指向,一个或多个的参数) |