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

首頁 > 編程 > JavaScript > 正文

js中let能否完全替代IIFE

2019-11-19 11:20:36
字體:
來源:轉載
供稿:網友

前言

最近,我寫了一篇關于syntax of Java's IIFE pattern的文章,來解釋為什么我們用現在的方式來寫立即執行函數表達式。少數的讀者批評文章過時了,都在爭論在ECMA 2015中介紹的塊級作用域變量使IIFE變得過時了。

恰恰相反,立即執行函數表達式一點也沒有過時!因為這個理由,我決定寫這篇后續文章來介紹一些立即執行函數表達式的常見用法。注意以下的列表是不完整的,所以如果你喜歡的用法沒有在文章出現,希望你不要有什么不好的感覺。

函數作用域 VS 塊級作用域

通過var關鍵字聲明的本地變量僅作用于當前閉包域,如果不存在這樣的一個閉包函數,那么將會創建一個污染全局作用域的全局變量。為了防止這種情況出現,我們可以使用IIFE來創建一個包含有這個本地變量的函數。

(function(){varfoo= "bar";console.log(foo);})();foo;// ReferenceError: foo is not defined

目前的爭論是,我們可以使用在ECMA 2015介紹的塊級作用域變量來代替IIFE,以達到相同的效果。相比于函數級作用域,let和const關鍵字聲明的本地變量僅作用于當前所處的”塊”級域。

{let foo= "bar";console.log(foo);}foo;// ReferenceError: foo is not defined

然而,塊級作用域變量不是立即函數執行表達式的替代品。確實,如果支持ECMA 2015,let和const能夠用來限制本地變量只在包含它的塊級作用域內使用。

如果,你在不支持ECMA 2015的環境(例如一些舊的瀏覽器)中執行你的Java代碼。你就不能使用let和const關鍵字來創建塊級作用域變量。你將不得不求助于以前經典的函數級作用域方法。

閉包和私有數據

IIFE的另一個用法是為局部變量提供一個封裝的作用域,在IIFE返回的函數中能夠訪問該變量。這種方式即_a closure is created_允許函數訪問這個本地變量,即使這個函數在IIFE的詞法范圍之外執行時。

假設我們要創建一個uniqueId函數,每次調用該函數時就會返回一個唯一的id(比如 “id_1”,“id_2”等)。在下面的IIFE中,記錄了一個私有的計數變量(count),每次調用計數函數uniqueId的時候,就會將count加一。我們在IIFE中返回的另一個函數,這個函數在調用時會返回一個新的標識符字符串。

constuniqueId= (function(){let count= 0;returnfunction(){++count;returnid_${count};};})();console.log(uniqueId());// "id_1"console.log(uniqueId());// "id_2"console.log(uniqueId());// "id_3"

注意,在IIEF之外無法訪問這個計數變量count。除了從IIEF中返回的函數,別人無法讀寫該變量。這樣就能創建真正的私有狀態,它只能以受控的方式進行修改。revealing module pattern非常依賴于這種機制。

constcounter= (function(){let counterValue= 0;return{increment(){++counterValue;},get value(){returncounterValue;}};})();counter.increment();console.log(counter.value);// 1counter.increment();counter.increment();console.log(counter.value);// 3

當使用IIFE來返回一個”封閉”一些本地變量來管理私有數據的函數時,let和const都不能替代它。

變量重命名

有時,你可能碰到一種情況,你正在使用的兩個不同的庫暴露的全局變量名是相同的。例如,考慮一下你正在使用jQuery同時另一個庫也指定了一個為$的全局變量。

為了解決命名沖突問題,可以將一段代碼封裝在一個IIEF中,將一個全局變量(比如,jQuery)作為參數傳入IIFE。在函數內部,就可以以一個任意的參數名(比如,$)來訪問該參數值:

window.$= functionsomethingElse(){// ...};(function($){// ...})(jQuery);

不管在外部作用域有什么值指定給$,在IIFE中,這些值都會被”屏蔽”,$參數一直指向jQuery方法。

捕獲全局對象

Java代碼在不同環境執行時,你所使用的全局對象是不同的。當代碼在瀏覽器運行時,全局對象是windows。但是在Node.js中,全局對象是global。由于在寫通用的Java代碼時,你肯定不想硬編碼這兩個名字其中的任何一個,這時你就可以使用一種”包裝”的方式就像下面這樣:

(function(global){// ...})(this);

不管是瀏覽器還是Node.js的環境,global參數將會指定到對的全局對象上。如果想了解更多關于使用這種技巧來捕獲全局對象的細節內容,請移步this post by Todd Motto。

壓縮方面的優化

混疊變量名的方法也可以用來優化代碼,這種方式使代碼能夠被更有效的壓縮。舉例如下:

(function(window,document,undefined){// ...})(window,document);

更短標識符名會使文件的體積變得更小。然而,如果HTTP的返回內容通過Gzip或者Deflate進行壓縮,文件的大小已經被很有效的壓縮了。因此,如果結合壓縮算法,壓縮技術的邊際收益會變得更小。所以自己權衡和比較返回內容的大小,較短的名字可能仍然是有作用的。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁都县| 三亚市| 寿宁县| 普宁市| 上思县| 寻乌县| 临武县| 河南省| 舟山市| 江达县| 古丈县| 元朗区| 延长县| 石家庄市| 吉安县| 宝山区| 平顶山市| 宝清县| 呼伦贝尔市| 米脂县| 禹州市| 抚顺县| 莫力| 光山县| 漠河县| 丹江口市| 博爱县| 利川市| 长武县| 江华| 大新县| 加查县| 舟山市| 营口市| 老河口市| 丰镇市| 庆云县| 隆尧县| 孝感市| 石河子市| 沈丘县|