关于javascript:slicecallarguments原理解析

javascirpt的类数组对象能够像数组一样应用for循环遍历,然而却不能调用数组原型链的办法,为了让类数组对象能够像数组对象一样调用pushpop等办法,能够将类数组对象转成数组对象:

  • 将类数组对象转换成数组
var args = []; 
var obj = {0:"www",1:"jianshu",2:"com",length:3};
for (var i = 0; i < obj.length; i++) { 
    args.push(obj[i]);
}
console.log(args);  //["www","jianshu","com"]
//等价于以下的写法
console.log([].slice.call(obj));  //["www","jianshu","com"]

了解[].slice.call(arguments)的原理,须要明确:

  • slice()办法的作用
  • call()办法的作用
  • slice()办法的外部实现
  • Array.prototype.slice()
console.log([1,2,3,4,5].slice(0,1)); //[1]
console.log([1,2,3,4,5].slice(1,3)); //[2,3]
console.log([1,2,3,4,5].slice(3)); //[4,5]
console.log([1,2,3,4,5].slice()); //[1,2,3,4,5]

数组的slice(start,end)办法,返回从start开始到end的子数组,如果startend都没有设置,则返回整个数组,这个过程不影响原数组。

  • Function.prototype.call()
function func(name, price) {
  this.name = name;
  this.price = price;
}
var food = {name:"apple",price:10};
func.call(food,"orange",15);
console.log(food); // {name: "orange", price: 15}

调用call办法传入的参数比原办法多一个参数,简略来说,call办法的作用就是:用call办法的第一个参数代替func办法外部的this,其余参数为原func办法的参数。

  • slice办法外部实现
    slice办法外部实现,V8源码第587行,其基本原理就相似咱们下面结尾写的for循环遍历原数组,依据start和end的值再复制一份到新数组并返回。所以当咱们应用[].slice.call(arguments),slice办法外部的this就会被替换成arguments,并循环遍历arguments,复制到新数组返回,这样就失去了一个复制arguments类数组的数组对象。
  • 为了进步性能,缩小一层对原型链的追溯,个别咱们会采纳以下的写法
Array.prototype.slice.call(arguments)

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理