小編給大家分享一下緩存調(diào)用鏈如何實(shí)現(xiàn)JS方法的重載,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的莒南網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
方法重載是指在一個(gè)類中定義多個(gè)同名的方法,但要求每個(gè)方法具有不同的參數(shù)的類型或參數(shù)的個(gè)數(shù)。
簡而言之就是:方法重載就是方法名稱重復(fù),加載參數(shù)不同。
具體看請(qǐng)左轉(zhuǎn): 方法重載/百度百科
那么js如何實(shí)現(xiàn)這個(gè)呢???
首先javascript是沒有重載函數(shù)/方法這個(gè)概念的,但是js提供了一個(gè)arguments這個(gè)方法參數(shù),通過這個(gè)參數(shù)的length屬性就可以拿到方法參數(shù)的長度,o~對(duì)了,咱們今天實(shí)現(xiàn)的也僅僅是按照參數(shù)長度重載,而不是參數(shù)類型~~·length ,
那么及下載呢,一旦有了方法參數(shù)長度,于是出現(xiàn)了比常見的switch寫法:
var seven={ dosomething:function(){ switch(arguments.length){ case 0: console.log(arguments.length); //dosomething break; case 1: console.log(arguments.length); //dosomething break; case 2: //dosomething console.log(arguments.length); break; } } }
wow~如果10個(gè)方法就需要10個(gè)分支~而且很不好維護(hù)~因?yàn)槊總€(gè)方法體都在case下,或者單獨(dú)提出來寫成一個(gè)function~
然后這些都是不好的~不易維護(hù)的,逼格不夠高的~那么咱們應(yīng)該如何優(yōu)雅的實(shí)現(xiàn)對(duì)于不同參數(shù)的同一方法名的處理呢?
這就用到這個(gè) apply 這個(gè)方法了.
咱們?yōu)閟even編寫一個(gè)addMethod
方法
var seven = { addMethod: function (fname, func) { var old = this[fname]; this[fname] = function () { if (arguments.length == func.length) { return func.apply(this,arguments); } if (typeof old == 'function') { return old.apply(this, arguments); } } } };
修改后的seven如上,然后之前寫的switch就可以這樣搞了:
seven.addMethod('dosomething', function (x) { console.log(arguments.length); //dosomething }); seven.addMethod('dosomething', function (x,y) { console.log(arguments.length); //dosomething }); seven.addMethod('dosomething', function (x,y,z) { console.log(arguments.length); //dosomething });
咱們要增加方法,只需要調(diào)用這個(gè)addMethod方法就ok了,是不是覺得簡單明了,更加清晰。
那么這段代碼的原理呢,其實(shí)也很簡單,就是緩存舊方法,然后根據(jù)參數(shù)長度依次apply鏈?zhǔn)秸{(diào)用,直到找到和當(dāng)前參數(shù)等長的方法~然后進(jìn)行調(diào)用。
func
和 old
很有可能讓初來乍到的童鞋們迷惑,其實(shí)不然,這里巧妙的使用了JavaScript語言的特性,這個(gè)old每一次保存的都是上一次方法的引用,而且每次都是全新的,而舊的old又保持著引用,這是什么呢?閉包嘍~。
以上是“緩存調(diào)用鏈如何實(shí)現(xiàn)JS方法的重載”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
當(dāng)前名稱:緩存調(diào)用鏈如何實(shí)現(xiàn)JS方法的重載
分享網(wǎng)址:http://m.rwnh.cn/article34/jipcse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供、做網(wǎng)站、App設(shè)計(jì)、網(wǎng)站改版、微信小程序、營銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)