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

javascript閉包功能與用法實例分析

 更新時間:2017年04月06日 14:47:02   作者:布瑞澤的童話  
這篇文章主要介紹了javascript閉包功能與用法,結合具體實例形式深入淺出的分析了javascript中閉包的概念、功能、使用方法與相關注意事項,需要的朋友可以參考下

本文實例講述了javascript閉包功能與用法。分享給大家供大家參考,具體如下:

理解閉包

閉包這個東西,確實是很麻煩。之前我自己的理解也是有一點誤差,所以今天將文章修改修改,爭取將自己的理解進一步準確化。

閉包說得通熟易懂一點,就是指有權訪問另一個函數(shù)作用域的變量的函數(shù)。創(chuàng)建閉包的常見方式,就是在一個函數(shù)內部創(chuàng)建另外一個函數(shù),并返回

我們這里舉一個例子來說明,首先我們在函數(shù)f1內部定義一個函數(shù)f2。

function f1(){
  var n=999;
  function f2(){
    alert(n); // 999
  }
}

f2可以訪問f1的作用域,反過來就不行了?,F(xiàn)在我們想訪問f1中的n,在外層卻訪問不到,怎么辦呢?將f2作為f1的返回值就可以了:

function f1(){
  var n=999;
  function f2(){
    alert(n);
  }
  return f2;
}
var result=f1();
result(); // 999

這個就是閉包。

其實也很簡單,那么閉包有什么用呢?

閉包的使用

之前的自己只知道閉包的概念,卻并不知道其存在的價值和意義。直到自己在項目中遇到類似的問題后,才發(fā)現(xiàn)只有閉包才能解決的情況。

閉包是使用可以帶來以下好處

1. 希望一個變量長期駐扎在內存中
2. 避免全局變量的污染
3. 私有成員的存在

我們剛才說到過,閉包可以讀取到函數(shù)內部的變量,這是由于閉包后函數(shù)的堆棧不會釋放,也就是說這些值始終保持在內存中。這是一個優(yōu)點,也是一個缺點。

我們可以通過閉包來實現(xiàn)一個計數(shù)器,而不用擔心全局變量的污染:

function f1(){
  var n=999;
  nAdd=function(){n+=1}
  function f2(){
    alert(n);
  }
  return f2;
}
var result=f1();
result(); // 999
nAdd();
result(); // 1000

可以看到n一直存儲在內存中,并沒有在f1調用后被自動清除。

我們再來看看如何通過閉包來模擬JavaScript中的私有成員:

var aaa = (function(){
  var a = 1;
  function bbb(){
    a++;
    alert(a);
  }
  function ccc(){
    a++;
    alert(a);
  }
  return {
    b:bbb,    //json結構
    c:ccc
  }
})();
aaa.b();  //2
aaa.c();  //3

這樣就可以提供指定的變量供外界訪問了。

閉包解決的問題

這是一個很常見的問題,就是利用javascript處理循環(huán)的時候,索引i的值不能有效的利用:

這里改成如下格式,形成10個閉包來解決即可:

更多關于JavaScript相關內容可查看本站專題:《javascript面向對象入門教程》、《JavaScript中json操作技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數(shù)學運算用法總結

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

相關文章

  • javascript使用中為什么10..toString()正常而10.toString()出錯呢

    javascript使用中為什么10..toString()正常而10.toString()出錯呢

    在JavaScript中為什么10..toString()正常,而10.toString()出錯呢?這個問題一直困擾著我,所抽時間搜集整理下,曬出來與大家分享感興趣的朋友可以了解下,希望對你們有幫助
    2013-01-01
  • JavaScript Typescript基礎使用教程

    JavaScript Typescript基礎使用教程

    TypeScript是Microsoft(微軟)開發(fā)的一種開源編程語言,它充分利用了JavaScript原有的對象模型,并在此基礎上進行了擴充,TypeScript設計目標是開發(fā)大型應用,它可以編譯成純JavaScript,編譯出來的JavaScript可以運行在任何一種JS運行環(huán)境中
    2022-12-12
  • js仿淘寶評價評分功能

    js仿淘寶評價評分功能

    本文主要介紹了js仿淘寶評價評分功能——點擊心形生成得分(有半心選擇),具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • 原生js實現(xiàn)移動開發(fā)輪播圖、相冊滑動特效

    原生js實現(xiàn)移動開發(fā)輪播圖、相冊滑動特效

    原生JS實現(xiàn)圖片自動輪播緩沖切換特效,很實用流暢的圖片輪播特效,在較現(xiàn)代的瀏覽器上展現(xiàn)的圓角效果,兼容差點的是直角效果,全部原生JS實現(xiàn),還是很不錯的值得大家學習并利用,推薦下載。
    2015-04-04
  • javaScript 刪除字符串空格多種方法小結

    javaScript 刪除字符串空格多種方法小結

    在js中自一些字符串刪除空格的功能,本文章來介紹了字符串刪除功能加利用正則快速替換字符串中所有空格實現(xiàn)代碼
    2012-10-10
  • JS如何獲取對象鍵值對中key值的方法

    JS如何獲取對象鍵值對中key值的方法

    這篇文章主要介紹了JS如何獲取對象鍵值對中key值的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • js中json處理總結之JSON.parse

    js中json處理總結之JSON.parse

    parse是解析json數(shù)據(jù)多種方法中的其中一種。這篇文章主要介紹了js中json處理總結之JSON.parse,需要的朋友可以參考下
    2016-10-10
  • Exif.js圖片旋轉修正的方法

    Exif.js圖片旋轉修正的方法

    這篇文章主要為大家詳細介紹了Exif.js圖片旋轉修正的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • javascript函數(shù)的四種調用模式

    javascript函數(shù)的四種調用模式

    本文詳細介紹了javascript函數(shù)的四種調用模式。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • JavaScript命令模式原理與用法實例詳解

    JavaScript命令模式原理與用法實例詳解

    這篇文章主要介紹了JavaScript命令模式原理與用法,結合實例形式詳細分析了JavaScript命令模式基本概念、原理、用法及操作注意事項,需要的朋友可以參考下
    2020-03-03

最新評論