久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 如何講清楚閉包?

如何講清楚閉包?

來源:千鋒教育
發(fā)布人:qyf
時(shí)間: 2022-10-10 16:20:23 1665390023

  我們都知道一個(gè)概念。

  在JS當(dāng)中,一個(gè)函數(shù)可以訪問其外部的變量資源。

圖片 1

  但以下這種情況會(huì)出錯(cuò)。

  function m1(){

  var a = 100;

  console.log(a++);

  }

  function m2(){

  console.log(a++); //這里無法訪問a

  }

  如果,我們想在m2的作用域里,訪問m1里的變量,就像下面這樣:

圖片 2

  首先,我們可以在m1的內(nèi)部創(chuàng)建一個(gè)函數(shù)m3

  function m1(){

  var a = 100;

  function m3(){

  console.log(a++);

  }

  }

圖片 3

  m3可以正常訪問a,接下來我們?cè)黾右粋€(gè)return操作。

  function m1(){

  var a = 100;

  return function m3(){

  console.log(a++);

  }

  }

  既然有了返回值,那我們不妨接收一下,繼續(xù)編寫代碼如下:

  function m1(){

  var a = 100;

  return function m3(){

  console.log(a++);

  }

  }

  var _m3 = m1();

  我們執(zhí)行了函數(shù)m1, 并將返回值賦值給_m3,

  那么目前_m3和m3函數(shù)是等價(jià)的,即它們是同一個(gè)函數(shù)。

  有了_m3,一切都好辦了。我們繼續(xù)編寫代碼

  function m1(){

  var a = 100;

  return function m3(){

  console.log(a++);

  }

  }

  var _m3 = m1();

  function m2(){

  _m3();

  }

  因?yàn)開m3是全局變量,因此m2可以調(diào)用_m3

  也就等價(jià)于m2間接的,訪問到了變量a

圖片 4

  通常,我們管m3,叫做一個(gè)『 閉包函數(shù) 』

  下面列舉幾個(gè)常見的閉包場(chǎng)景:

  01

  for(var i=0; i<list.length; p="" i++){<="">

  var item = list[i];

  item.onclick = (function(num){

  return function(){

  //......

  }

  })(i);

  }

  02

  function (){

  var that = this;

  setTimeout(function(){

  //......

  },2000)

  }

  03

  function User(){

  var _age = 0;

  this.getAge = function(){

  return _age;

  }

  this.setAge = function(age){

  this._age = age;

  }

  }

  04

  (function(){

  var cache = [...];

  return {

  get : function(){

  //...

  }

  };

  })()

  05

  (function(){

  var t = null;

  return function(){

  if(!t){

  t = create();

  }

  }

  })()

  為了創(chuàng)造閉包,有時(shí)候會(huì)寫函數(shù)自調(diào)用

  可以不這么麻煩么??

  當(dāng)然,那就是使用let。

  例如

  for(let i=0; i<list.length; p="" i++){<="">

  let item = list[i];

  item.onclick = function(){

  console.log(i);

  //觀察變量i的值

  };

  }

  關(guān)于閉包的疑問

  當(dāng)函數(shù)m1執(zhí)行完成的時(shí)候,內(nèi)部的變量a,理論上應(yīng)該被回收掉了。

圖片20

  可是為什么變量a依然可以被訪問呢?

  主要是因?yàn)?,m3還在引用它

圖片21

  垃圾回收器顯然不會(huì)回收一個(gè)依然被引用的變量。

  除非這個(gè)變量,已經(jīng)無人引用,即是說,它已經(jīng)無法再內(nèi)存里被找到。

  此時(shí)才可以當(dāng)做垃圾處理。

  不過m3可以訪問變量a這種規(guī)則,并不是在所有編程語言里都生效的。因此,這也算是JS的特性之一。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
大數(shù)據(jù)測(cè)試工程師需要具備哪些技能?

一、理解大數(shù)據(jù)概念大數(shù)據(jù)測(cè)試工程師需要理解大數(shù)據(jù)的基本概念和原理,如分布式存儲(chǔ)、MapReduce、實(shí)時(shí)計(jì)算等。他們還需要了解如何處理大規(guī)模的...詳情>>

2023-10-14 23:43:03
為什么SpringBoot的 jar 可以直接運(yùn)行?

一、JAR文件的結(jié)構(gòu)與執(zhí)行方式Spring Boot的JAR包是Java Archive的縮寫,它是一種壓縮文件格式,可以將Java項(xiàng)目的類文件、資源文件以及依賴庫等...詳情>>

2023-10-14 23:01:49
站群服務(wù)器是什么?

站群服務(wù)器的含義與用途站群服務(wù)器主要用于支持站群,即由一組相互鏈接的網(wǎng)站組成的群體。這些網(wǎng)站通常由同一組織或個(gè)人擁有,并且經(jīng)常會(huì)互相鏈...詳情>>

2023-10-14 22:46:12
自編碼器是什么?

一、自編碼器原理自編碼器的設(shè)計(jì)靈感源于神經(jīng)科學(xué)中關(guān)于感知系統(tǒng)的認(rèn)知原理,它的核心思想是將輸入數(shù)據(jù)經(jīng)過編碼過程,形成一個(gè)隱藏層的特征表示...詳情>>

2023-10-14 22:41:10
什么是云網(wǎng)融合?

一、云網(wǎng)融合的定義云網(wǎng)融合是指將云計(jì)算與網(wǎng)絡(luò)技術(shù)相結(jié)合,實(shí)現(xiàn)資源的共享、業(yè)務(wù)的協(xié)同,將網(wǎng)絡(luò)與云端服務(wù)深度融合,提供更靈活、高效、安全的...詳情>>

2023-10-14 22:31:47