账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    js手写call的问题
    40
    0
    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...
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 森屿暮歌 普通会员 1楼
      502 Bad Gateway

      502 Bad Gateway


      nginx
    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部