面试官:你能手写实现call,apply,bind方法吗?

2019-03-04

[实践系列] 主要是让我们通过实践去加深对一些原理的理解。

实践系列-前端路由

实践系列-Babel原理

实践系列-Promises/A+规范

实践系列-浏览器缓存机制

有兴趣的同学可以关注 我的博客,之后不断会有干货更新哦。 求star求follow~

三兄弟的作用.

apply.call.bind 都是为了改变函数运行时上下文(this指向)而存在的。

image

三兄弟的区别.

  • 三兄弟接收的第一个参数都是 要绑定的this指向.
  • apply的第二个参数是一个参数数组,call和bind的第二个及之后的参数作为函数实参按顺序传入。
  • bind不会立即调用,其他两个会立即调用。

image

接下来,我们来对三兄弟进行模拟实现

call的简易模拟实现(es6)

思路

call是可以被所有方法调用的,所以毫无疑问的定义在 Function的原型上!

绑定函数被调用时只传入第二个参数及之后的参数

如果调用者函数,被某一个对象所拥有,那么该函数在调用时,内部的this指向该对象。

ojbk..理清了思路.开撸

image

apply的简易模拟实现(es6)

apply实现的思路与call基本相同,我们只需要对参数进行不同处理即可

image

bind的简易模拟实现(es6)

思路

bind是可以被所有方法调用的,所以毫无疑问的定义在 Function的原型上!

bind函数返回一个绑定函数,最终调用需要传入函数实参和绑定函数的实参!!

如果调用者函数,被某一个对象所拥有,那么该函数在调用时,内部的this指向该对象。

image

End

如果有帮助到你,请给我一个star,就算是对我的感谢啦~

原文链接:segmentfault.com

上一篇:「前端早读君010」重学前端day1: HTML基础
下一篇:vueX10分钟入门
相关教程
关注微信

扫码加入 JavaScript 社区

相关文章

首次访问,需要验证
微信扫码,关注即可
(仅需验证一次)

欢迎加入 JavaScript 社区

号内回复关键字:

回到顶部