妙用緩存調(diào)用鏈實(shí)現(xiàn)JS方法的重載
1.什么是方法重載
方法重載是指在一個(gè)類中定義多個(gè)同名的方法,但要求每個(gè)方法具有不同的參數(shù)的類型或參數(shù)的個(gè)數(shù)。
簡而言之就是:方法重載就是方法名稱重復(fù),加載參數(shù)不同。
具體看請(qǐng)左轉(zhuǎn): 方法重載/百度百科
那么js如何實(shí)現(xiàn)這個(gè)呢???
2. js如何實(shí)現(xiàn)?
首先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;
}
}
}
3.優(yōu)化
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又保持著引用,這是什么呢?閉包嘍~。
相關(guān)文章
JS判斷輸入字符串長度實(shí)例代碼(漢字算兩個(gè)字符,字母數(shù)字算一個(gè))
下面小編就為大家?guī)硪黄狫S判斷輸入字符串長度實(shí)例代碼(漢字算兩個(gè)字符,字母數(shù)字算一個(gè))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08
echarts拖拽滑塊dataZoom-slider自定義樣式簡單適配移動(dòng)端
在電腦端和移動(dòng)端的數(shù)據(jù)展示中,針對(duì)移動(dòng)端的特殊性,進(jìn)行了一系列優(yōu)化措施,這篇文章主要介紹了echarts拖拽滑塊dataZoom-slider自定義樣式簡單適配移動(dòng)端的相關(guān)資料,需要的朋友可以參考下2024-09-09
js中刪除數(shù)組中的某一元素實(shí)例(無下標(biāo)時(shí))
下面小編就為大家?guī)硪黄猨s中刪除數(shù)組中的某一元素實(shí)例(無下標(biāo)時(shí))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
Js動(dòng)態(tài)添加復(fù)選框Checkbox的實(shí)例方法
Js動(dòng)態(tài)添加復(fù)選框Checkbox的實(shí)例方法,需要的朋友可以參考一下2013-04-04
JavaScript中new操作符的原理與實(shí)現(xiàn)詳解
你知道new嗎?你知道new的實(shí)現(xiàn)原理嗎?你能手寫new方法嗎?不要擔(dān)心,這篇文件就來帶大家深入了解一下JavaScript中的new操作符,感興趣的小伙伴可以學(xué)習(xí)一下2022-10-10
動(dòng)態(tài)加載外部javascript文件的函數(shù)代碼分享
動(dòng)態(tài)加載外部javascript文件的函數(shù)代碼分享,做個(gè)記錄備忘,方便查找。2011-07-07

