欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

JavaScript中惰性函數(shù)的示例分析

這篇文章主要介紹JavaScript中惰性函數(shù)的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

創(chuàng)新互聯(lián)公司是一家專業(yè)提供北鎮(zhèn)企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、做網(wǎng)站、H5網(wǎng)站設(shè)計(jì)、小程序制作等業(yè)務(wù)。10年已為北鎮(zhèn)眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。

需求

我們現(xiàn)在需要寫一個(gè) foo 函數(shù),這個(gè)函數(shù)返回首次調(diào)用時(shí)的 Date 對(duì)象,注意是首次。

解決一:普通方法

var t;
function foo() {
 if (t) return t;
 t = new Date()
 return t;
}

問題有兩個(gè),一是污染了全局變量,二是每次調(diào)用 foo 的時(shí)候都需要進(jìn)行一次判斷。

解決二:閉包

我們很容易想到用閉包避免污染全局變量。

var foo = (function() {
 var t;
 return function() {
 if (t) return t;
 t = new Date();
 return t;
 }
})();

然而還是沒有解決調(diào)用時(shí)都必須進(jìn)行一次判斷的問題。

解決三:函數(shù)對(duì)象

函數(shù)也是一種對(duì)象,利用這個(gè)特性,我們也可以解決這個(gè)問題。

function foo() {
 if (foo.t) return foo.t;
 foo.t = new Date();
 return foo.t;
}

依舊沒有解決調(diào)用時(shí)都必須進(jìn)行一次判斷的問題。

解決四:惰性函數(shù)

不錯(cuò),惰性函數(shù)就是解決每次都要進(jìn)行判斷的這個(gè)問題,解決原理很簡(jiǎn)單,重寫函數(shù)。

var foo = function() {
 var t = new Date();
 foo = function() {
 return t;
 };
 return foo();
};

更多應(yīng)用

DOM 事件添加中,為了兼容現(xiàn)代瀏覽器和 IE 瀏覽器,我們需要對(duì)瀏覽器環(huán)境進(jìn)行一次判斷:

// 簡(jiǎ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 時(shí)都會(huì)進(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)行條件判斷,其實(shí)只需要判斷一次,接下來的使用方式都不會(huì)發(fā)生改變的時(shí)候,想想是否可以考慮使用惰性函數(shù)。

以上是“JavaScript中惰性函數(shù)的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享標(biāo)題:JavaScript中惰性函數(shù)的示例分析
當(dāng)前地址:http://www.chinadenli.net/article12/pesgdc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)標(biāo)簽優(yōu)化移動(dòng)網(wǎng)站建設(shè)面包屑導(dǎo)航商城網(wǎng)站靜態(tài)網(wǎng)站

廣告

聲明:本網(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)

小程序開發(fā)