伪数组存在的意义
让一些对象也可以使用数组方法,可以通过
call() bind() apply()
方法实现
注意,方法的返回值类型不会改变,返回数组的还是会返回数组
常见的伪数组有哪些
伪数组在js中无法调用数组的方法,但跟数组长得很像,也有length属性.
1、函数中的参数 arguments, 是一个函数的属性,存储函数的实参数组对象
2、DOM 对象列表(比如通过 document.getElementsByTags 得到的列表)、childNodes也是伪数组
3、 对象(比如 $("div"))
2.2(像调用getElementsByTagName,document.childNodes)之类的伪数组 对象列表
真数组和伪数组的区别
伪数组:
1、拥有length属性
2、不具有数组的方法
3、伪数组是一个Object,真数组是Array
4、伪数组的长度不可变,真数组的长度是可变的5、可以通过
for in
遍历
伪数组怎么转真数组
1、let newArr=[ ].slice.call(argument)
2、let newArr = Array.protype.slice.call(伪数组)
3、let newArr = Array.from(伪数组),ES6的新语法
4、let newArr = [...伪数组],使用扩展运算符,也是ES6的语法利用Array的原型对象的slice方法,配合call()方法修改slice中this指向
ES6的from 和 扩展运算符(...) 将伪数组转化为真数组