国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

JS中使用apply、bind實現為函數或者類傳入動態個數的參數_javascript技巧

來源:懂視網 責編:小采 時間:2020-11-27 21:49:37
文檔

JS中使用apply、bind實現為函數或者類傳入動態個數的參數_javascript技巧

JS中使用apply、bind實現為函數或者類傳入動態個數的參數_javascript技巧:為紀念10年沒寫blog,第一篇博文就以這樣一個有趣的竅門開始吧 -___- 在ES5中,當我們調用一個函數時,如果要傳入的參數是根據其他函數或條件判斷生成的,也就是說不確定會傳入多少個參數時,在不改變原函數的情況下該如何辦呢? (當然了,能避免此文所述情
推薦度:
導讀JS中使用apply、bind實現為函數或者類傳入動態個數的參數_javascript技巧:為紀念10年沒寫blog,第一篇博文就以這樣一個有趣的竅門開始吧 -___- 在ES5中,當我們調用一個函數時,如果要傳入的參數是根據其他函數或條件判斷生成的,也就是說不確定會傳入多少個參數時,在不改變原函數的情況下該如何辦呢? (當然了,能避免此文所述情
為紀念10年沒寫blog,第一篇博文就以這樣一個有趣的竅門開始吧 -___-

在ES5中,當我們調用一個函數時,如果要傳入的參數是根據其他函數或條件判斷生成的,也就是說不確定會傳入多少個參數時,在不改變原函數的情況下該如何辦呢?

(當然了,能避免此文所述情況發生就盡量避免,比如將參數改為object或array等等)


大部分人可能知道用apply能完美解決這個問題:


apply與call一樣會將第一個參數作為函數的調用對象,即改寫了調用函數內的this指針為第一個參數,如果不是對象的方法,可以不考慮this,傳入一個null即可。

而不同之處在于后面的參數,apply將所有要傳入調用函數的參數放在一個數組中,call是與原函數一樣依次追加進去。


既然是數組那就可控了,根據其他函數或邏輯判斷來生成數組,可達到傳入動態個數參數的目的。

但是我遇到一個頭疼的問題,要在用new創建對象時傳入動態個參數,幾年才遇到一次的問題:


如果是用ES6,有了rest參數,上述問題全都不是問題。注意,數組args前面加三個點并不是語法錯誤,而是ES6提供的rest參數寫法,你可以理解為將...args替換為args數組去掉方括號后的字符。


但ES5里真的就沒有辦法實現了嗎?畢竟ES6大部分都是語法糖,可以用babel一類的工具編譯為ES5,帶著疑問,我們就用babel編譯一下看看得到什么:


看到最后一行驚呆了,別害怕,讓我們分析一下這句代碼。首先肢解一下,分三步來看:


1. 毫無疑問,用concat將null與我們的參數連接為一個數組,作為apply第二個參數,即得到[null, 1, 2, 3];

2. 讓我們運算一下apply,第一個參數Foo會取代Function來調用原生的bind方法,第二個參數數組的內容將作為bind的參數傳入,即得到Foo.bind(null, 1, 2, 3);

3. bind方法第一個參數與apply、call類似,修改this指針,而后面的參數可以為函數植入默認的前置參數值(preset leading argument),也就是說當bind執行完后在第一組小括號內我們得到一個已經注入了三個參數值的Foo類,暫且叫FooWithArgs;

最終,當我們 new FooWithArgs(); 時,就不用傳入任何參數了。等同于 new Foo(1, 2, 3);

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JS中使用apply、bind實現為函數或者類傳入動態個數的參數_javascript技巧

JS中使用apply、bind實現為函數或者類傳入動態個數的參數_javascript技巧:為紀念10年沒寫blog,第一篇博文就以這樣一個有趣的竅門開始吧 -___- 在ES5中,當我們調用一個函數時,如果要傳入的參數是根據其他函數或條件判斷生成的,也就是說不確定會傳入多少個參數時,在不改變原函數的情況下該如何辦呢? (當然了,能避免此文所述情
推薦度:
標簽: js ap 的參數
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 五月天婷婷久久 | 欧美日韩性生活 | 国产精品久久久久9999 | 亚洲三级在线 | 国产精品一区二区综合 | 97精品高清一区二区三区 | 一区高清| 亚洲国产 | 欧美综合在线视频 | 国产资源视频在线观看 | 欧美精品一区二区三区在线播放 | 精品一区二区三区五区六区七区 | 欧美不卡在线视频 | 日韩精品在线视频 | 亚洲视频一区二区三区 | 国产精品观看 | 精品欧美成人高清视频在线观看 | 欧洲日韩 | 日韩亚洲欧美一区噜噜噜 | 欧美日韩亚洲区久久综合 | 亚洲伊人久久综合一区二区 | 欧美精品亚洲精品 | 国产精品va在线观看无 | 国产黄色片在线观看 | 精品欧美一区二区在线观看 | 亚洲高清视频在线 | 黄色a一级| 亚洲十欧美十日韩十国产 | 亚洲人成网站999久久久综合 | 欧美日韩综合精品一区二区三区 | 国产精品免费观看视频播放 | 国产丝袜美女一区二区三区 | 国产一区二区三区夜色 | 日韩欧美视频一区二区三区 | 亚洲日本一区二区三区高清在线 | 护士精品一区二区三区 | 国产精品久久久久久久久免费 | 欧美综合第一页 | 欧美精品日韩一区二区三区 | www.亚洲一区 | 国产夜夜操 |