call原理+封装一个call

2019-03-21  本文已影响0人  广告位招租

call

首先需要了解一下call的使用方法

let obj = {
  name: 'zhangsan'
}

function a() {
  console.log(this)
  console.log(this.name)
}
a.call(obj)
image.png

this指向了obj,所以我们需要做的是,改变一下this的指向

封装一个call

Function.prototype._call = function(...arg) {
  let _one = [...arg][0]
  _one.fn = this // 注意,这里的this指向的是调用_call的函数
   let result = _one.fn(...[...arg].slice(1)) // 将后续的参数传入函数,在这一步实现了this指向传入的第一个参数
  delete _one.fn // 别忘了删掉增加的属性
  return result
}
function a(...args) {
  console.log(this.name)
  console.log(...args)
}
a._call(obj, 1, 2)
image.png

这里要注意this之间的转变,开始的this指向的是调用call的方法,但是之后执行方法的时候,this将会指向传入的对象,实现call方法

上一篇 下一篇

猜你喜欢

热点阅读