欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript學(xué)習(xí)筆記之惰性函數(shù)示例詳解

 更新時間:2017年08月27日 09:09:15   作者:冴羽  
函數(shù)是js世界的一等公民,js的動態(tài)性、易變性在函數(shù)的應(yīng)用上,體現(xiàn)的淋漓盡致。下面這篇文章主要給大家介紹了關(guān)于JavaScript學(xué)習(xí)筆記之惰性函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。

前言

本文主要給大家介紹了關(guān)于JavaScript惰性函數(shù)的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(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 的時候都需要進行一次判斷。

解決二:閉包

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

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

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

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

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

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

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

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

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

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

更多應(yīng)用

DOM 事件添加中,為了兼容現(xiàn)代瀏覽器和 IE 瀏覽器,我們需要對瀏覽器環(huá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ù),我們可以這樣做:

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

重要參考

Lazy Function Definition Pattern

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • js實現(xiàn)選中頁面文字將其分享到新浪微博

    js實現(xiàn)選中頁面文字將其分享到新浪微博

    這篇文章主要介紹了js實現(xiàn)選中頁面文字將其分享到新浪微博,需要的朋友可以參考下
    2015-11-11
  • 原生JS實現(xiàn)的輪播圖功能詳解

    原生JS實現(xiàn)的輪播圖功能詳解

    這篇文章主要介紹了原生JS實現(xiàn)的輪播圖功能,結(jié)合實例形式分析了javascript實現(xiàn)輪播圖的原理、操作技巧與相關(guān)注意事項,需要的朋友可以參考下
    2018-08-08
  • Bootstrap treeview實現(xiàn)動態(tài)加載數(shù)據(jù)并添加快捷搜索功能

    Bootstrap treeview實現(xiàn)動態(tài)加載數(shù)據(jù)并添加快捷搜索功能

    本文實現(xiàn)了運用bootstrap treeview實現(xiàn)動態(tài)加載數(shù)據(jù),并且添加快捷搜索功能,需要的朋友參考下
    2018-01-01
  • 在bootstrap中實現(xiàn)輪播圖實例代碼

    在bootstrap中實現(xiàn)輪播圖實例代碼

    Bootstrap中輪播圖插件叫作Carousel ,下面通過本文給大家詳細介紹了bootstrop中實現(xiàn)輪播圖效果,需要的朋友參考下
    2017-06-06
  • 詳解uniapp分包的實現(xiàn)方式及優(yōu)點

    詳解uniapp分包的實現(xiàn)方式及優(yōu)點

    當(dāng)今移動應(yīng)用開發(fā)領(lǐng)域,隨著用戶對于應(yīng)用功能和體驗的要求不斷提高,應(yīng)用程序的復(fù)雜度也在不斷增加,在這種情況下,應(yīng)用程序的體積也隨之增大,為了解決這個問題,Uniapp提供了分包功能,本文將詳細介紹Uniapp分包的功能和優(yōu)勢,包括如何通過配置文件實現(xiàn)分包
    2023-09-09
  • js獲取TreeView控件選中節(jié)點的Text和Value值的方法

    js獲取TreeView控件選中節(jié)點的Text和Value值的方法

    在實際項目中,遇到一個問題,首先彈出一個新窗口,新窗口中放了一個TreeView控件,現(xiàn)在要解決的是,如何單擊TreeView中一個節(jié)點,返回Text和Value到父頁面并關(guān)閉該新窗口,本文將詳細介紹此方法的實現(xiàn)
    2012-11-11
  • JavaScript實現(xiàn)三級聯(lián)動效果

    JavaScript實現(xiàn)三級聯(lián)動效果

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)三級聯(lián)動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • openlayers實現(xiàn)地圖彈窗

    openlayers實現(xiàn)地圖彈窗

    這篇文章主要為大家詳細介紹了openlayers實現(xiàn)地圖彈窗,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • javascript數(shù)組中的concat方法和splice方法

    javascript數(shù)組中的concat方法和splice方法

    這篇文章主要介紹了javascript數(shù)組中的concat方法和splice方法,concat方法作用合并數(shù)組,可以合并一個或多個數(shù)組,會返回合并數(shù)組之后的數(shù)據(jù),不會改變原來的數(shù)組,更多相關(guān)內(nèi)容需要的小伙伴可以參考下面文章內(nèi)容
    2022-03-03
  • ES6學(xué)習(xí)筆記之map、set與數(shù)組、對象的對比

    ES6學(xué)習(xí)筆記之map、set與數(shù)組、對象的對比

    這篇文章主要給大家介紹了關(guān)于ES6學(xué)習(xí)筆記之map、set與數(shù)組、對象對比的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03

最新評論