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

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

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

前言

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

实践系列-前端路由

实践系列-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函数吗?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

我是一只IT小小鸟

我是一只IT小小鸟

胡江堂、李成、唐雅薇、秦琴、蒋宇东、刘未鹏、居振梁、刘帅、温卫斌、张弦、张凯峰、庄表伟、宋劲杉、程露、黄小明、易晓东、简朝阳、林健、高昂、徐宥、辜新星 / 电子工业出版社 / 2009 / 29.80

一群IT小小鸟—— 来自十几所院校,或男生,或女生;或科班,或半路转行。 分布在不同的公司,或外企,或国企,或民企,老板有土有洋。 有失意,有快意;有泪水,有欢笑。在失望中追求希望,在迷茫中辨别方向。 他们用自己的成长故事,告诉在校的师弟师妹们: 青春太宝贵,千万别浪费;要想不浪费,万事早准备。一起来看看 《我是一只IT小小鸟》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具