面试官:你能手写call,apply,bind函数吗?

栏目: JavaScript · 发布时间: 6年前

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

前言

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

实践系列-前端路由

实践系列-Babel原理

实践系列-Promises/A+规范

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

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

三兄弟的作用.

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

面试官:你能手写call,apply,bind函数吗?

三兄弟的区别.

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

面试官:你能手写call,apply,bind函数吗?

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

call的简易模拟实现(es6)

思路

  • 函数定义在哪里 ?

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

  • 函数接收参数 ?

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

  • 如何显式绑定this ?

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

ojbk..理清了思路.开撸

面试官:你能手写call,apply,bind函数吗?

apply的简易模拟实现(es6)

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

面试官:你能手写call,apply,bind函数吗?

bind的简易模拟实现(es6)

思路

  • 函数定义在哪里 ?

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

  • 函数接收参数 ?

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

  • 如何显式绑定this ?

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

面试官:你能手写call,apply,bind函数吗?

End

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


以上所述就是小编给大家介绍的《面试官:你能手写call,apply,bind函数吗?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java语言精粹

Java语言精粹

Jim Waldo / 王江平 / 电子工业出版社 / 2011-6 / 39.00元

这是一本几乎只讲java优点的书。 Jim Waldo先生是原sun微系统公司实验室的杰出工程师,他亲历并参与了java从技术萌生、发展到崛起的整个过程。在这《java语言精粹》里,jim总结了他所认为的java语言及其环境的诸多精良部分,包括:类型系统、异常处理、包机制、垃圾回收、java虚拟机、javadoc、集合、远程方法调用和并发机制。另外,他还从开发者的角度分析了在java技术周围......一起来看看 《Java语言精粹》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具