您好,登錄后才能下訂單哦!
小編給大家分享一下緩存調用鏈如何實現JS方法的重載,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
方法重載是指在一個類中定義多個同名的方法,但要求每個方法具有不同的參數的類型或參數的個數。
簡而言之就是:方法重載就是方法名稱重復,加載參數不同。
具體看請左轉: 方法重載/百度百科
那么js如何實現這個呢???
首先javascript是沒有重載函數/方法這個概念的,但是js提供了一個arguments這個方法參數,通過這個參數的length屬性就可以拿到方法參數的長度,o~對了,咱們今天實現的也僅僅是按照參數長度重載,而不是參數類型~~·length ,
那么及下載呢,一旦有了方法參數長度,于是出現了比常見的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個方法就需要10個分支~而且很不好維護~因為每個方法體都在case下,或者單獨提出來寫成一個function~
然后這些都是不好的~不易維護的,逼格不夠高的~那么咱們應該如何優雅的實現對于不同參數的同一方法名的處理呢?
這就用到這個 apply 這個方法了.
咱們為seven編寫一個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 });
咱們要增加方法,只需要調用這個addMethod方法就ok了,是不是覺得簡單明了,更加清晰。
那么這段代碼的原理呢,其實也很簡單,就是緩存舊方法,然后根據參數長度依次apply鏈式調用,直到找到和當前參數等長的方法~然后進行調用。
func
和 old
很有可能讓初來乍到的童鞋們迷惑,其實不然,這里巧妙的使用了JavaScript語言的特性,這個old每一次保存的都是上一次方法的引用,而且每次都是全新的,而舊的old又保持著引用,這是什么呢?閉包嘍~。
以上是“緩存調用鏈如何實現JS方法的重載”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。