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

深入解析JavaScript的閉包機(jī)制

 更新時(shí)間:2015年10月20日 17:33:47   投稿:goldensun  
這篇文章主要介紹了JavaScript的閉包機(jī)制,針對(duì)內(nèi)嵌函數(shù)的變量訪問(wèn)等問(wèn)題分析了JS的閉包,需要的朋友可以參考下

JavaScript 變量可以是局部變量或全局變量。
私有變量可以用到閉包。
全局變量
函數(shù)可以訪問(wèn)是有函數(shù)內(nèi)部定義的變量,如:
實(shí)例

function myFunction() {
  var a = 4;
  return a * a;
}


函數(shù)也可以訪問(wèn)函數(shù)外部定義的變量,如:
實(shí)例

var a = 4;
function myFunction() {
  return a * a;
}

后面一個(gè)實(shí)例中, a 是一個(gè) 全局 變量。
在web頁(yè)面中全局變量屬于 window 對(duì)象。
全局變量可應(yīng)用于頁(yè)面上的所有腳本。
在第一個(gè)實(shí)例中, a 是一個(gè) 局部 變量。
局部變量只能用于定義它函數(shù)內(nèi)部。對(duì)于其他的函數(shù)或腳本代碼是不可用的。
全局和局部變量即便名稱相同,它們也是兩個(gè)不同的變量。修改其中一個(gè),不會(huì)影響另一個(gè)的值。
Note 
變量聲明是如果不使用 var 關(guān)鍵字,那么它就是一個(gè)全局變量,即便它在函數(shù)內(nèi)定義。

變量生命周期
全局變量的作用域是全局性的,即在整個(gè)JavaScript程序中,全局變量處處都在。
而在函數(shù)內(nèi)部聲明的變量,只在函數(shù)內(nèi)部起作用。這些變量是局部變量,作用域是局部性的;函數(shù)的參數(shù)也是局部性的,只在函數(shù)內(nèi)部起作用。
計(jì)數(shù)器困境
設(shè)想下如果你想統(tǒng)計(jì)一些數(shù)值,且該計(jì)數(shù)器在所有函數(shù)中都是可用的。
你可以使用全局變量,函數(shù)設(shè)置計(jì)數(shù)器遞增:
實(shí)例

var counter = 0;

function add() {
  counter += 1;
}

add();
add();
add();

// 計(jì)數(shù)器現(xiàn)在為 3

計(jì)數(shù)器數(shù)值在執(zhí)行 add() 函數(shù)時(shí)發(fā)生變化。
但問(wèn)題來(lái)了,頁(yè)面上的任何腳本都能改變計(jì)數(shù)器,即便沒(méi)有調(diào)用 add() 函數(shù)。
如果我在函數(shù)內(nèi)聲明計(jì)數(shù)器,如果沒(méi)有調(diào)用函數(shù)將無(wú)法修改計(jì)數(shù)器的值:
實(shí)例

function add() {
  var counter = 0;
  counter += 1;
}

add();
add();
add();

// 本意是想輸出 3, 但事與愿違,輸出的都是 1 !

以上代碼將無(wú)法正確輸出,每次我調(diào)用 add() 函數(shù),計(jì)數(shù)器都會(huì)設(shè)置為 1。
JavaScript 內(nèi)嵌函數(shù)可以解決該問(wèn)題。
JavaScript 內(nèi)嵌函數(shù)
所有函數(shù)都能訪問(wèn)全局變量。 
實(shí)際上,在 JavaScript 中,所有函數(shù)都能訪問(wèn)它們上一層的作用域。
JavaScript 支持嵌套函數(shù)。嵌套函數(shù)可以訪問(wèn)上一層的函數(shù)變量。
該實(shí)例中,內(nèi)嵌函數(shù) plus() 可以訪問(wèn)父函數(shù)的 counter 變量:
實(shí)例

function add() {
  var counter = 0;
  function plus() {counter += 1;}
  plus();  
  return counter; 
}

如果我們能在外部訪問(wèn) plus() 函數(shù),這樣就能解決計(jì)數(shù)器的困境。
我們同樣需要確保 counter = 0 只執(zhí)行一次。
我們需要閉包。
JavaScript 閉包
還記得函數(shù)自我調(diào)用嗎?該函數(shù)會(huì)做什么?
實(shí)例

var add = (function () {
  var counter = 0;
  return function () {return counter += 1;}
})();

add();
add();
add();

// 計(jì)數(shù)器為 3

實(shí)例解析
變量 add 指定了函數(shù)自我調(diào)用的返回字值。
自我調(diào)用函數(shù)只執(zhí)行一次。設(shè)置計(jì)數(shù)器為 0。并返回函數(shù)表達(dá)式。
add變量可以作為一個(gè)函數(shù)使用。非常棒的部分是它可以訪問(wèn)函數(shù)上一層作用域的計(jì)數(shù)器。
這個(gè)叫作 JavaScript 閉包。它使得函數(shù)擁有私有變量變成可能。
計(jì)數(shù)器受匿名函數(shù)的作用域保護(hù),只能通過(guò) add 方法修改。

Note 
閉包是可訪問(wèn)上一層函數(shù)作用域里變量的函數(shù),即便上一層函數(shù)已經(jīng)關(guān)閉。

相關(guān)文章

  • Array.slice()與Array.splice()的返回值類型

    Array.slice()與Array.splice()的返回值類型

    Array.slice()與Array.splice()的返回值類型...
    2006-10-10
  • JavaScript 無(wú)符號(hào)右移賦值操作

    JavaScript 無(wú)符號(hào)右移賦值操作

    無(wú)符號(hào)右移賦值操作 (>>>=)是對(duì)變量值根據(jù)表達(dá)式值所規(guī)定的位數(shù)進(jìn)行無(wú)符號(hào)右移,并將結(jié)果賦給該變量。
    2009-04-04
  • javascript中eval解析JSON字符串

    javascript中eval解析JSON字符串

    這篇文章主要介紹了javascript中eval解析JSON字符串時(shí)遇到的一個(gè)問(wèn)題,簡(jiǎn)單的說(shuō)eval就相當(dāng)于一個(gè)js解析器,很牛哦
    2016-02-02
  • window.navigate 與 window.location.href 的使用區(qū)別介紹

    window.navigate 與 window.location.href 的使用區(qū)別介紹

    首先說(shuō)明的是 window.navigate 與 window.location.href 都是實(shí)現(xiàn)頁(yè)面鏈接跳轉(zhuǎn)的,下面將介紹它們的區(qū)別。感興趣的朋友可以參考下
    2013-09-09
  • Javascript基礎(chǔ)教程之變量

    Javascript基礎(chǔ)教程之變量

    大家都知道javascript是可以隱式聲名變量的。但要注意,隱式聲名變量總是被創(chuàng)建為全局變量??匆韵麓a,情愿javascript語(yǔ)言強(qiáng)制聲明變量。建議大家一定要var聲明變量。
    2015-01-01
  • JavaScript String 對(duì)象常用方法詳解

    JavaScript String 對(duì)象常用方法詳解

    下面小編就為大家?guī)?lái)一篇JavaScript String 對(duì)象常用方法詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-05-05
  • EsLint入門(mén)學(xué)習(xí)教程

    EsLint入門(mén)學(xué)習(xí)教程

    ESLint是一個(gè)代碼規(guī)范和錯(cuò)誤檢查工具,下面這篇文章主要介紹了EsLint的相關(guān)資料,需要的朋友可以參考學(xué)習(xí),下面來(lái)一起看看吧。
    2017-02-02
  • 理解javascript回調(diào)函數(shù)

    理解javascript回調(diào)函數(shù)

    這篇文章主要介紹了理解javascript回調(diào)函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2014-12-12
  • JavaScript DOM學(xué)習(xí)第八章 表單錯(cuò)誤提示

    JavaScript DOM學(xué)習(xí)第八章 表單錯(cuò)誤提示

    這一章詳細(xì)介紹的表單錯(cuò)誤提示的方法比那種大多數(shù)使用警告框的方法要好的多。
    2010-02-02
  • javascript操作css屬性

    javascript操作css屬性

    今天因需要用到j(luò)s獲取css屬性,網(wǎng)上搜了半天都不合適的。有一下幾種方法
    2013-12-12

最新評(píng)論