一、简介:
通俗来讲apply和call的作用都是改变调用函数的对象。其中apply中第二个参数是数组,call将参数排列在第二、三、。。。个参数上
二、apply源码解读
apply源码就不贴了,有意向的可以直接百度,这里仅仅指出其中的几个要点
1、调用对象的转换
首先给apply函数的第一个参数对象(A)中添加一个函数(B)——该函数就是调用apply函数的那个函数;
这样,通过A直接调用B就可以实现调用对象的转换。
但是这里存在一个问题,调用时参数怎么传,难道直接将第二个参数数组传过去,熟悉apply的人会发现,这根apply的实现不同。所以需要进行参数的重构
2、参数重构——将apply中传入的第二个参数数组通过逐一判断转换为字符串
问题又来了:直接将字符串传入,还是不能达到要求
3、上述问题的解决办法:构造一个新函数,通过字符串拼接,将函数体和参数合二为一,形成一个完整的A调用B的函数。
三、call源码解读
其实,其实,它与apply的三个基本点是一致的。所不同的就是传递参数的方式是参数序列而不是数组。
在这些过程中有一个js基本点就是字符串拼接,比如数组和字符串相加的结果,一些对此不熟悉的人可以相对注意
"a"+[1,2,3]+3结果为a1,2,33
bind()与apply和call的区别:当你希望改变上下文环境之后并非立即执行,而是回调执行的时候,使用 bind() 方法。bind 是返回对应函数,便于稍后调用;apply 、call 则是立即调用 。