国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JavaScript中消除閉包的一般方法介紹

2024-05-06 16:16:57
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了JavaScript中消除閉包的一般方法介紹,本文直接給出了操作示例,需要的朋友可以參考下
 

JavaScript 的閉包是一個其主動發展的特性, 也是一個被動發展的特性. 也就是說, 一方面, JS 有了閉包能更好解決一些問題. 另一方面, JS 為了解決某些問題, 而不得不使用閉包勉強來解決問題.

前者這里不討論, 如果 JS 閉包能更好的解決問題, 當然使用閉包更好.

我討論的是后者, 是因為 JS 本身的限制, 而不得不磕磕絆絆地用閉包來解決的問題, 例如"變量只初始化一次"這樣的需求.

常規的語言這樣解決:

復制代碼代碼如下:

class Class{
 function init(){
  this.n = 0;
 }
 function func(){
  this.n ++;
  return this.n;
 }
}
var obj = new Class();

 

JavaScript 一般會這樣解決(使用閉包):

 

復制代碼代碼如下:

var obj = {
 func : (function(){
  var n = 0;
  return function(){
   n ++;
   return n;
  }
 })()
}

 

但我更建議采用這種方法(消除閉包):

 

復制代碼代碼如下:

function Class(){
 var self = this;
 self.n = 0;
 self.func = function(){
  self.n ++;
  return self.n;
 }
}
var obj = new Class();

 

因為后者的可擴展性更好. 當你需要實現對一個變量的不同操作時, 后一種可以只需要再定義一個不同的函數(也就是簡單線性擴展), 而前一種(閉包)則需要完全重寫(這就是為什么你經常聽到重構這個詞的原因).


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

圖片精選

主站蜘蛛池模板: 长子县| 昌都县| 永仁县| 临泉县| 岢岚县| 梁平县| 时尚| 峨眉山市| 巴东县| 宁远县| 水富县| 论坛| 杂多县| 南和县| 垦利县| 泸州市| 开江县| 巫山县| 辽阳市| 岗巴县| 明水县| 巧家县| 大足县| 宜宾市| 安新县| 精河县| 佳木斯市| 泰顺县| 诸暨市| 宝应县| 莲花县| 威宁| 昌都县| 云安县| 邵阳市| 正蓝旗| 荆州市| 新郑市| 淮南市| 廊坊市| 哈密市|