javascript 閉包詳解
來源:易賢網 閱讀:718 次 日期:2015-02-27 13:29:56
溫馨提示:易賢網小編為您整理了“javascript 閉包詳解”,方便廣大網友查閱!

這篇文章主要詳細介紹了javascript 閉包的相關資料,十分詳盡,需要的朋友可以參考下

javascript 閉包是一個很有趣的東東??戳诵┫嚓P資料,對其印象最深刻的是:實現了public 和private。

創建一個非匿名閉包最簡單的語法是:

代碼如下:

var obj = (function(){//各種代碼 });

閉包最經典的例子:

代碼如下:

var makeCounter = (function () {

var i = 1;

this.test=function(){

console.log(i);

i++;

}

return this;

});

var obj = makeCounter();

obj.test(); // 1

obj.test(); // 2

var obj1 = makeCounter();

obj1.test(); // 1

obj1.test(); // 2

private 與 public :

代碼如下:

var makeCounter= (function () {

var i = 1;

//這貨是private的

function log(){

console.log(i);

i++;

}

//這貨是public的

this.test(){

log();

}

return this;

});

var obj = makeCounter();

obj.test(); // 1

obj.test(); // 2

obj.log(); //undefined

自執行函數:

  第一次看到這樣的代碼時的感覺是:好高級;

代碼如下:

var obj = (function(window){

//各種代碼

}(window));

  然后google了下,發現他們經常都會這樣寫:

代碼如下:

var obj= (function () {

var i = 1;

this.test=function(){

console.log(i);

i++;

}

return this;

}());

obj.test(); // 1

obj.test(); // 2

最簡單的理解,程序員偷懶把兩步寫成了一步。

代碼如下:

//這是一個函數。它應該這樣用obj()

var makeCounter = function () {

//各種代碼

}

//這是一個對象。它類似于 var obj = makeCounter();

var obj = (function () {

//各種代碼

}());

  它也可以有參數:

代碼如下:

var output = "new test";

var obj = (function (msg) {

this.test = function(){

console.log(msg);

}

return this;

}(output));

obj.test();

  它還可以更復雜更高級點:

代碼如下:

var output = "new test";

var obj = (function (obj, msg) {

//這貨也是私有的。類似obj.i(!=obj.i),卻又不是obj.i(因為外部不可訪問)。

var i = 1;

//private

function log() {

console.log(i + " : " + msg);

i++;

}

//public

obj.test = function () {

log();

}

return obj;

}(obj, output));

obj.test(); // 1 : new test

obj.i = 100;

//i沒被改變

obj.test(); // 2 : new test

初次見面,留下了很深刻的印象。閉包的使用,實現了狀態,屬性的保持;避免了全局變量滿屏飛舞;結束了變量老是被重定義,重賦值的尷尬局面。它還可以將一個對象分部到多個js文件。實在是太好了。

上面所述就是本文的全部內容了,希望大家能夠喜歡。

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
下一篇:JavaScript簡介
易賢網手機網站地址:javascript 閉包詳解
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看