JavaScript學(xué)習(xí)筆記之惰性函數(shù)示例詳解
前言
本文主要給大家介紹了關(guān)于JavaScript惰性函數(shù)的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧。
需求
我們現(xiàn)在需要寫一個 foo 函數(shù),這個函數(shù)返回首次調(diào)用時的 Date 對象,注意是首次。
解決一:普通方法
var t;
function foo() {
if (t) return t;
t = new Date()
return t;
}
問題有兩個,一是污染了全局變量,二是每次調(diào)用 foo 的時候都需要進(jìn)行一次判斷。
解決二:閉包
我們很容易想到用閉包避免污染全局變量。
var foo = (function() {
var t;
return function() {
if (t) return t;
t = new Date();
return t;
}
})();
然而還是沒有解決調(diào)用時都必須進(jìn)行一次判斷的問題。
解決三:函數(shù)對象
函數(shù)也是一種對象,利用這個特性,我們也可以解決這個問題。
function foo() {
if (foo.t) return foo.t;
foo.t = new Date();
return foo.t;
}
依舊沒有解決調(diào)用時都必須進(jìn)行一次判斷的問題。
解決四:惰性函數(shù)
不錯,惰性函數(shù)就是解決每次都要進(jìn)行判斷的這個問題,解決原理很簡單,重寫函數(shù)。
var foo = function() {
var t = new Date();
foo = function() {
return t;
};
return foo();
};
更多應(yīng)用
DOM 事件添加中,為了兼容現(xiàn)代瀏覽器和 IE 瀏覽器,我們需要對瀏覽器環(huán)境進(jìn)行一次判斷:
// 簡化寫法
function addEvent (type, el, fn) {
if (window.addEventListener) {
el.addEventListener(type, fn, false);
}
else if(window.attachEvent){
el.attachEvent('on' + type, fn);
}
}
問題在于我們每當(dāng)使用一次 addEvent 時都會進(jìn)行一次判斷。
利用惰性函數(shù),我們可以這樣做:
function addEvent (type, el, fn) {
if (window.addEventListener) {
addEvent = function (type, el, fn) {
el.addEventListener(type, fn, false);
}
}
else if(window.attachEvent){
addEvent = function (type, el, fn) {
el.attachEvent('on' + type, fn);
}
}
}
當(dāng)然我們也可以使用閉包的形式:
var addEvent = (function(){
if (window.addEventListener) {
return function (type, el, fn) {
el.addEventListener(type, fn, false);
}
}
else if(window.attachEvent){
return function (type, el, fn) {
el.attachEvent('on' + type, fn);
}
}
})();
當(dāng)我們每次都需要進(jìn)行條件判斷,其實只需要判斷一次,接下來的使用方式都不會發(fā)生改變的時候,想想是否可以考慮使用惰性函數(shù)。
重要參考
Lazy Function Definition Pattern
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
javascript生成不重復(fù)的隨機(jī)數(shù)
這篇文章主要介紹了javascript在指定范圍內(nèi)生成不重復(fù)的隨機(jī)數(shù)的方法和相關(guān)實例,有需要的小伙伴可以參考下。2015-07-07
JS檢索下拉列表框中被選項目的索引號(selectedIndex)
這篇文章主要介紹了JS檢索下拉列表框中被選項目的索引號(selectedIndex),本文通過實例代碼圖文詳解的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下2019-12-12
微信sdk實現(xiàn)禁止微信分享(使用原生php實現(xiàn))
這篇文章主要介紹了微信sdk實現(xiàn)禁止微信分享(使用原生php實現(xiàn)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11

