Javascript 之 call 办法的应用和实现
面试的时候常常会遇到手写 bind,apply,call 办法的口试题,明天咱们就来看看 call 办法是什么并实现一下 call 办法,免得面试的时候答复不上来。
首先理解一下 call 办法是什么,实现了什么性能。
看看 MDN 上的介绍
Function.prototype.call()**call()**
办法应用一个指定的 this
值和独自给出的一个或多个参数来调用一个函数。
示例:
var hello = function (a, b, c, d) {console.log(this.name);
console.log(a, b, c, d)
};
var demo = {name: 'demo'};
var h = hello.call(demo, 1, 2, 3, 4);
// demo
// 1 2 3 4
能够看到啊,apply 办法中的 this 指向是传进来的第一个对象,传进来的其余参数,顺次传到原函数中,最初把后果输入就行了,上面咱们来简略实现下。
Function.prototype.myCall = function () {const obj = arguments[0]
obj.tempFunction = this
const params = []
for (let i = 1; i < arguments.length; i++) {params.push(arguments[i])
}
const res = obj.tempFunction(...params)
delete obj.tempFunction
return res
}
call 办法的实现就要用到 arguments 了,不然那么多参数从不能都用形参吧哈哈。当然下面还有很多很多要优化的中央,比如说参数的校验,params 的定义占据了额定的内存空间,解构的办法不兼容老的浏览器,然而总的来说思路是这样的,优化的事件,就交给各位看官吧。