亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

Javascript閉包用法實例分析

2024-05-06 16:15:09
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Javascript閉包的概念及用法,以實例形式深入淺出的分析了閉包的功能及使用時的注意事項,非常具有實用價值,需要的朋友可以參考下
 

本文實例分析了Javascript閉包的概念及用法。分享給大家供大家參考。具體如下:

提到閉包,想必大家都早有耳聞,下面說下我的簡單理解。
說實話平時工作中實際手動寫閉包的場景并不多,但是項目中用到的第三方框架和組件或多或少用到了閉包。
所以,了解閉包是非常必要的。呵呵...

一、什么是閉包

簡而言之,就是能夠讀取其他函數內部變量的函數。
由于JS變量作用域的特性,外部不能訪問內部變量,內部可以外部變量。

二、使用場景

1. 實現私有成員。
2. 保護命名空間,避免污染全局變量。
3. 緩存變量。

先看一個封裝的例子:

復制代碼代碼如下:
var person = function () {
    // 變量作用域為函數內部,外部無法訪問
    var name = "default";

 

    return {
        getName: function () {
            return name;
        },
        setName: function (newName) {
            name = newName;
        }
    }
}();

console.log(person.name); // 直接訪問,結果為:undefined
console.log(person.getName()); // 結果為:default
console.log(person.setName("langjt"));
console.log(person.getName()); // 結果為:langjt

 

再看循環中常用閉包解決引用外部變量問題:

復制代碼代碼如下:
var aLi = document.getElementsByTagName('li');
for (var i=0, len=aLi.length; i<len; i++) {
   aLi[i].onclick = function() {
     alert(i); // 無論點擊哪個<li>元素,彈出的值都為len,表明這里的i和在for之后打印i的值是一樣的。
   };
}

使用閉包后:
復制代碼代碼如下:
var aLi = document.getElementsByTagName('li');
for (var i=0, len=aLi.length; i<len; i++) {
  aLi[i].onclick = (function(i) {
    return function() {
      alert(i); // 此時點擊<li>元素,就會彈出對應的下標了。
    }
  })(i);
}

 

三、注意事項

1. 內存泄漏

由于閉包會使得函數中的變量都被保存在內存中,內存消耗很大,所以不能濫用閉包,否則會造成網頁的性能問題。
比如:

復制代碼代碼如下:
function foo() {
   var oDiv = document.getElementById(‘J_DIV');
   var id = oDiv.id;
   oDiv.onclick = function() {
     // alert(oDiv.id); 這里存在循環引用,IE低版本頁面關閉后oDiv仍在內存中。所以盡可能緩存基本類型而不是對象。
     alert(id);
   };
   oDiv = null;
}

 

2. 變量命名

如果內部函數的變量和外部函數的變量名相同時,那么內部函數再也無法指向外部函數那個同名的變量。
比如:

復制代碼代碼如下:
function foo(num) {
  return function(num) {
    console.log(num); 
  }
}
var f = new foo(9);
f(); // undefined

 

其實上面的用法,專業術語叫函數柯里化(Currying),就是把接受多個參數的函數變換成接受一個單一參數(最初函數的第一個參數)的函數,并且返回接受余下的參數而且返回結果的新函數的技術。本質上也利用了閉包可以緩存的特性,比如:

復制代碼代碼如下:
var adder = function(num) {
    return function(y) {
        return num+y;
    };
};

 

var inc = adder(1);
var dec = adder(-1);
//inc, dec現在是兩個新的函數,作用是將傳入的參數值 (+/‐)1
alert(inc(99));//100
alert(dec(101));//100 
alert(adder(100)(2));//102 
alert(adder(2)(100));//102

 

再比如阿里玉伯的seaJS源碼中:

復制代碼代碼如下:
/**
 * util-lang.js - The minimal language enhancement
 */
function isType(type) {
  return function(obj) {
    return {}.toString.call(obj) == "[object " + type + "]"
  }
}

 

var isObject = isType("Object");
var isString = isType("String");

 

希望本文所述對大家的javascript程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品在线视频| 热99精品只有里视频精品| 亚洲乱亚洲乱妇无码| 久久激情视频久久| 3344国产精品免费看| 国产色视频一区| 在线亚洲欧美视频| 国产精品久久婷婷六月丁香| 中文字幕国内精品| 国产ts人妖一区二区三区| 欧美丝袜第一区| 日韩av中文字幕在线免费观看| 怡红院精品视频| 97视频色精品| 亚洲精品视频网上网址在线观看| 这里精品视频免费| 欧美成人自拍视频| 国产亚洲精品美女久久久久| 国产精品久久久久久婷婷天堂| 国产精品久久久久久av福利软件| 国产精品美乳一区二区免费| 国产日韩在线亚洲字幕中文| 欧美极品少妇xxxxⅹ免费视频| 欧美激情视频免费观看| 日韩在线视频网| 国产在线拍揄自揄视频不卡99| 欧美日韩在线另类| 亚洲国产精久久久久久久| 深夜福利国产精品| 日韩精品亚洲视频| 日韩国产欧美精品一区二区三区| 久久久噜噜噜久久中文字免| 色狠狠av一区二区三区香蕉蜜桃| 亚洲在线观看视频| 国产精品成久久久久三级| 国产精品日韩在线播放| 92看片淫黄大片看国产片| 国产成人在线播放| 亚洲精品美女视频| 欧美专区在线视频| 欧美精品videos性欧美| 日韩理论片久久| 亚洲欧美日本伦理| 中文字幕av一区二区| 欧美性猛交99久久久久99按摩| 国产午夜精品理论片a级探花| 国产成人小视频在线观看| 91网站免费看| 欧美激情精品久久久久久黑人| 亚洲自拍在线观看| 国产成人在线亚洲欧美| 海角国产乱辈乱精品视频| 在线播放日韩精品| 日韩在线观看高清| 国产一区私人高清影院| 国产精品露脸自拍| 国产欧美精品久久久| 国产在线拍揄自揄视频不卡99| 国产精品伦子伦免费视频| 欧美一级淫片播放口| 91精品美女在线| 国产精品福利久久久| 欧美日韩亚洲激情| 亚洲激情视频在线播放| 久久久国产精品x99av| 日韩欧美国产黄色| 91国产视频在线| 欧美成人午夜激情在线| 色777狠狠综合秋免鲁丝| 欧美国产高跟鞋裸体秀xxxhd| 亚洲欧美激情精品一区二区| 精品久久香蕉国产线看观看亚洲| 日韩中文字幕不卡视频| 日韩国产在线播放| 亚洲成人在线视频播放| 欧美亚洲国产日本| 奇米影视亚洲狠狠色| 亚洲国产美女久久久久| 亚洲片av在线| 亚洲天堂av在线免费观看| 国产成人精品在线观看| 成人免费在线视频网站| 亚洲高清在线观看| 国产亚洲欧美日韩精品| 欧美亚洲视频在线观看| 日韩在线欧美在线| 91系列在线播放| 黑人巨大精品欧美一区二区免费| 日韩精品日韩在线观看| 孩xxxx性bbbb欧美| 日韩中文字幕网站| 精品国产一区av| 日韩av一卡二卡| 精品久久久香蕉免费精品视频| 精品一区二区亚洲| 尤物九九久久国产精品的分类| 欧美情侣性视频| 中国人与牲禽动交精品| 国内揄拍国内精品少妇国语| 欧美黑人一级爽快片淫片高清| 亚洲欧美日韩在线高清直播| 日韩在线视频二区| 伊人久久久久久久久久| 欧美亚洲视频在线观看| 亚洲护士老师的毛茸茸最新章节| 日韩欧美中文第一页| 亚洲第一在线视频| 欧美日韩亚洲91| 亚洲国产精品久久久久秋霞不卡| 懂色av中文一区二区三区天美| 久久久久久久97| 精品视频在线播放免| 国产精品中文字幕在线| 97在线观看视频国产| 国产成人黄色av| 久久亚洲成人精品| 亚洲色图综合久久| 高清视频欧美一级| 九色成人免费视频| 久久久久久久久久久人体| 久久高清视频免费| www.久久久久久.com| 在线看日韩av| 久久久999国产精品| 热re99久久精品国产66热| 欧美大秀在线观看| 欧美成人在线免费| 91国在线精品国内播放| 亚洲国产精品成人av| 另类色图亚洲色图| 成人h视频在线观看播放| 亚洲国产精品网站| 成人免费在线网址| 国产一区二区三区在线播放免费观看| 最近2019年好看中文字幕视频| 黑人巨大精品欧美一区二区三区| 中文字幕成人在线| 国产精品久久久久久五月尺| 91精品国产高清久久久久久91| www.国产一区| 亚洲丝袜在线视频| 亚洲成人在线视频播放| 91精品在线一区| 国产99久久久欧美黑人| 成人亚洲欧美一区二区三区| 欧美激情免费看| 97色在线视频| 九九精品在线视频| 91免费观看网站| 日韩在线观看视频免费| 人人做人人澡人人爽欧美| 神马久久桃色视频| 久久综合免费视频| 欧美视频在线看| 欧美性视频在线| 精品久久久久久电影| 亚洲男女性事视频| 欧美日韩免费看| 91中文字幕在线观看| 国产精品高潮呻吟久久av野狼| 国产精品激情av电影在线观看| 国产成人精品在线观看| 欧美性猛交视频| 国产精品扒开腿爽爽爽视频|