JS中使用apply、bind實(shí)現(xiàn)為函數(shù)或者類傳入動(dòng)態(tài)個(gè)數(shù)的參數(shù)
為紀(jì)念10年沒寫blog,第一篇博文就以這樣一個(gè)有趣的竅門開始吧 -___-
在ES5中,當(dāng)我們調(diào)用一個(gè)函數(shù)時(shí),如果要傳入的參數(shù)是根據(jù)其他函數(shù)或條件判斷生成的,也就是說不確定會(huì)傳入多少個(gè)參數(shù)時(shí),在不改變?cè)瘮?shù)的情況下該如何辦呢?
(當(dāng)然了,能避免此文所述情況發(fā)生就盡量避免,比如將參數(shù)改為object或array等等)
大部分人可能知道用apply能完美解決這個(gè)問題:
apply與call一樣會(huì)將第一個(gè)參數(shù)作為函數(shù)的調(diào)用對(duì)象,即改寫了調(diào)用函數(shù)內(nèi)的this指針為第一個(gè)參數(shù),如果不是對(duì)象的方法,可以不考慮this,傳入一個(gè)null即可。
而不同之處在于后面的參數(shù),apply將所有要傳入調(diào)用函數(shù)的參數(shù)放在一個(gè)數(shù)組中,call是與原函數(shù)一樣依次追加進(jìn)去。
既然是數(shù)組那就可控了,根據(jù)其他函數(shù)或邏輯判斷來生成數(shù)組,可達(dá)到傳入動(dòng)態(tài)個(gè)數(shù)參數(shù)的目的。
但是我遇到一個(gè)頭疼的問題,要在用new創(chuàng)建對(duì)象時(shí)傳入動(dòng)態(tài)個(gè)參數(shù),幾年才遇到一次的問題:
如果是用ES6,有了rest參數(shù),上述問題全都不是問題。注意,數(shù)組args前面加三個(gè)點(diǎn)并不是語法錯(cuò)誤,而是ES6提供的rest參數(shù)寫法,你可以理解為將...args替換為args數(shù)組去掉方括號(hào)后的字符。
但ES5里真的就沒有辦法實(shí)現(xiàn)了嗎?畢竟ES6大部分都是語法糖,可以用babel一類的工具編譯為ES5,帶著疑問,我們就用babel編譯一下看看得到什么:
看到最后一行驚呆了,別害怕,讓我們分析一下這句代碼。首先肢解一下,分三步來看:
1. 毫無疑問,用concat將null與我們的參數(shù)連接為一個(gè)數(shù)組,作為apply第二個(gè)參數(shù),即得到[null, 1, 2, 3];
2. 讓我們運(yùn)算一下apply,第一個(gè)參數(shù)Foo會(huì)取代Function來調(diào)用原生的bind方法,第二個(gè)參數(shù)數(shù)組的內(nèi)容將作為bind的參數(shù)傳入,即得到Foo.bind(null, 1, 2, 3);
3. bind方法第一個(gè)參數(shù)與apply、call類似,修改this指針,而后面的參數(shù)可以為函數(shù)植入默認(rèn)的前置參數(shù)值(preset leading argument),也就是說當(dāng)bind執(zhí)行完后在第一組小括號(hào)內(nèi)我們得到一個(gè)已經(jīng)注入了三個(gè)參數(shù)值的Foo類,暫且叫FooWithArgs;
最終,當(dāng)我們 new FooWithArgs(); 時(shí),就不用傳入任何參數(shù)了。等同于 new Foo(1, 2, 3);
- AngularJS報(bào)錯(cuò)$apply already in progress的解決方法分析
- AngularJS中$apply方法和$watch方法用法總結(jié)
- 詳解js中的apply與call的用法
- JS中使用apply方法通過不同數(shù)量的參數(shù)調(diào)用函數(shù)的方法
- 有關(guān)JavaScript中call()和apply() 的一些理解
- AngularJS中的$watch(),$digest()和$apply()區(qū)分
- JS中改變this指向的方法(call和apply、bind)
- js中apply和Math.max()函數(shù)的問題及區(qū)別介紹
相關(guān)文章
javascript閉包(Closure)用法實(shí)例簡(jiǎn)析
這篇文章主要介紹了javascript閉包(Closure)用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了JavaScript閉包的概念、功能及使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11JavaScript采用遞歸算法計(jì)算階乘實(shí)例
這篇文章主要介紹了JavaScript采用遞歸算法計(jì)算階乘,簡(jiǎn)單分析了javascript遞歸算法的相關(guān)使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08javascript背景時(shí)鐘實(shí)現(xiàn)方法
這篇文章主要介紹了javascript背景時(shí)鐘實(shí)現(xiàn)方法,涉及javascript時(shí)間及頁(yè)面元素樣式的相關(guān)操作技巧,需要的朋友可以參考下2015-06-06使用formatter函數(shù)設(shè)置Echarts的tooltip中動(dòng)態(tài)單位
這篇文章主要為大家介紹了使用formatter函數(shù)設(shè)置Echarts的tooltip中動(dòng)態(tài)單位實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07JS圖片放大效果簡(jiǎn)單實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)圖片放大效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09JS腳本加載后執(zhí)行相應(yīng)回調(diào)函數(shù)的操作方法
本文主要講解怎么在成功加載 js 文件后再執(zhí)行相應(yīng)回調(diào)任務(wù),對(duì)JS腳本加載后執(zhí)行相應(yīng)回調(diào)函數(shù)的操作方法感興趣的朋友,通過本文學(xué)習(xí)下吧2018-02-02javascript實(shí)現(xiàn)復(fù)選框超過限制即彈出警告框的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)復(fù)選框超過限制即彈出警告框的方法,涉及復(fù)選框及警告框的操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02