js手写call的问题

let result = context.fn(...arg); 这个地方为什么是隐式绑定,不太理解,隐式绑定不是对象调用方法的时候才是吗

// 思路:将~要改变this指向的方法,挂到目标对象上执行并返回
Function.prototype.myCall = function(context) {
    if(typeof this !== 'function') {
        throw new TypeError('not function')
    }
    context = context || window
    //***************************************************************************************************
    // 这三步也可以这样理解:
    // this指的就是调用call 方法的函数
    // 给当前上下文(call方法的第一个参数)添加一个属性fn,属性值为this,当前上下文就可以调用这个方法了。
    // 把call方法传入的其他的参数传入到属性fn指代的函数中,直接调用函数
    // f.myCall(obj) 就是将f方法添加到obj的属性中,f中的this 指向 obj
    
    context.fn = this;                   //this指向的是当前的函数(Function实例)
    let arg = [...arguments].slice(1);   //获取除了this指向对象以外的参数,空数组slice后返回仍是空数组
    let result = context.fn(...arg);     //隐式绑定,当前函数的this指向context
   //***************************************************************************************************
   delete context.fn
   return result
}

代码出处https://www.cnblogs.com/james...

阅读 1.6k
1 个回答
var foo = {
    name: 'my name'
}
function sayname(){
    console.log(this.name)
}
sayname.call(foo)

你看这个例子,你的源码里context.fn(...arg)前面这些代码的意思其实是组装了一下对象

foo = {
    name: 'my name',
    sayname(){
        console.log(this.name)
    }
}

也就是可以理解为foo.sayname(),那么sayname里的this自然就指向了foo,也就实现了call的效果

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题