call 和 apply 的功能相同庆捺,都是改變 this 的執(zhí)行古今,并立即執(zhí)行函數(shù)。區(qū)別在于傳參方式不同滔以。
func.call(thisArg, arg1, arg2, ...):第一個(gè)參數(shù)是 this 指向的對(duì)象捉腥,其它參數(shù)依次傳入。
func.apply(thisArg, [argsArray]):第一個(gè)參數(shù)是 this 指向的對(duì)象你画,第二個(gè)參數(shù)是數(shù)組或類數(shù)組抵碟。
一起思考一下,如何模擬實(shí)現(xiàn) call 撬即?
首先立磁,我們知道,函數(shù)都可以調(diào)用 call剥槐,說(shuō)明 call 是函數(shù)原型上的方法唱歧,所有的實(shí)例都可以調(diào)用。即: Function.prototype.call粒竖。
在 call 方法中獲取調(diào)用call()函數(shù)
如果第一個(gè)參數(shù)沒(méi)有傳入颅崩,那么默認(rèn)指向 window / global(非嚴(yán)格模式)
傳入 call 的第一個(gè)參數(shù)是 this 指向的對(duì)象,根據(jù)隱式綁定的規(guī)則蕊苗,我們知道 obj.foo(), foo() 中的 this 指向 obj;因此我們可以這樣調(diào)用函數(shù) thisArgs.func(...args)
返回執(zhí)行結(jié)果
圖片發(fā)自簡(jiǎn)書(shū)App
apply 的實(shí)現(xiàn)思路和 call 一致,僅參數(shù)處理略有差別朽砰。如下:
圖片發(fā)自簡(jiǎn)書(shū)App