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

1次阅读

共计 694 个字符,预计需要花费 2 分钟才能阅读完成。

前言
[实践系列] 主要是让我们通过实践去加深对一些原理的理解。
实践系列 - 前端路由
实践系列 -Babel 原理
实践系列 -Promises/A+ 规范
实践系列 - 浏览器缓存机制
有兴趣的同学可以关注 我的博客 , 之后不断会有干货更新哦。求 star 求 follow~
三兄弟的作用.
apply.call.bind 都是为了改变函数运行时上下文 (this 指向) 而存在的。

三兄弟的区别.

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

接下来, 我们来对三兄弟进行模拟实现
call 的简易模拟实现(es6)
思路
函数定义在哪里 ?
call 是可以被所有方法调用的, 所以毫无疑问的定义在 Function 的原型上!
函数接收参数 ?
绑定函数被调用时只传入第二个参数及之后的参数
如何显式绑定 this ?
如果调用者函数,被某一个对象所拥有,那么该函数在调用时,内部的 this 指向该对象。
ojbk.. 理清了思路. 开撸

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

bind 的简易模拟实现(es6)
思路
函数定义在哪里 ?
bind 是可以被所有方法调用的, 所以毫无疑问的定义在 Function 的原型上!
函数接收参数 ?
bind 函数返回一个绑定函数, 最终调用需要传入函数实参和绑定函数的实参!!
如何显式绑定 this ?
如果调用者函数,被某一个对象所拥有,那么该函数在调用时,内部的 this 指向该对象。

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

正文完
 0