JS笔记-part4(伪数组)

伪数组

伪数组的本质是个对象,它拥有数组三要素:元素、下标、长度,但不能调用数组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修改后的指向,一个或多个的参数)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章