functionfn1(){console.log(1);}functionfn2(){console.log(2);}**fn1.call(fn2);//输出1fn1.call.call(fn2);//输出2**fn1.call(fn2);//输出1我基本上能理解首先fn1通过原型链查找机制找到Function.prototype上的call方法,并且让call方法执行,此时call这个方法中的this就是要操作的fn1。在call方法代码执行的过程过程中,首先让fn1中的“this关键字”变为fn2,然后再让fn1这个方法执行。fn1.call.call(fn2);//输出2我始终没有摸透网上的文章看了不少也没有搞懂反应越乱了我的理解为将fn1.call当作一个整体还是fn1通过原型找到call方法call方法也是函数在通过原型找到call方法并让call执行将fn1.call中的关键字改为fn2并让fn1.call执行此时为什么就变为fn2执行了?
2 回答
MMTTMM
TA贡献1869条经验 获得超4个赞
开始我也没有理解在写个过程中逐渐理解了你可以先模拟一下call,尝试使用call2来解释Function.prototype.call2=function(context,...args){context=context||window;context.fn=this;constresult=context.fn(...args);deletecontext.fn;returnresult;};第一个,第二个都是按照你的方式输出。模拟是成功的。我们来看第二个fn1.call2===fn1.call2.call2//true则其实是fn1.call2===fn1.call2.call2===Function.prototype.call2其实调用方式为Function.prototype.call2.call2(fn2)至于为什么会被实质上是当前fn2被当作this指向了call。和fn1一点关系也没有最后发现实际写的call2一点用没有,发上去权当测试。
添加回答
举报
0/150
提交
取消