亚洲乱色熟女一区二区三区丝袜,天堂√中文最新版在线,亚洲精品乱码久久久久久蜜桃图片,香蕉久久久久久av成人,欧美丰满熟妇bbb久久久

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

js中IIFE(立即執(zhí)行函數(shù)表達式)到底是咋來的?

freeflydom
2025年7月3日 9:12 本文熱度 92

介紹

IIFE(Immediately Invoked Function Expression),中文名稱:立即執(zhí)行函數(shù)表達式,其實IIFE最早并不叫這個名字,而是叫做Self-Executing Anonymous Function,即自執(zhí)行匿名函數(shù)。根據(jù)MDN的資料,IIFE這個說法最早由Ben Alman于2010年提出,下面我們一起來看看這個名字的來龍去脈。

2010年11月5日,Ben Alman寫下來他的著名文章:Immediately-Invoked Function Expression (IIFE),標志著IIFE這個名字的誕生。

在文章中,Ben Alman稱他是一個對待術(shù)語非常嚴謹?shù)娜?,之前他多次看?code style="font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace, sans-serif; padding: 0px 5px; line-height: 1.8; margin: 0px 3px; display: inline-block; overflow-x: auto; vertical-align: middle; border-radius: 3px; background-color: rgb(251, 229, 225); color: rgb(192, 52, 29); border: none !important;">Self-Executing Anonymous Function這個說法,覺得不是很恰當,于是他提出了Immediately-Invoked Function Expression這個說法。

IIFE到底是咋來的?

當我們定義一個函數(shù)或者一個函數(shù)表達式時,你得到的是一個名字,通過這個名字,你就可以調(diào)用這個函數(shù)。

下面這兩段代碼,第一個定義了一個普通函數(shù),第二個定義了一個函數(shù)表達式,這兩種形式,我們都可以通過標識符foo來調(diào)用它們。

// 普通函數(shù)
function foo() {
  console.log('I am a function');
}
// 函數(shù)表達式
const foo = function() {
  console.log('I am a function expression');
};

也就是說,當javascript解釋器遇到全局function關(guān)鍵字,或者一個函數(shù)內(nèi)部的function關(guān)鍵字時,會將其解釋為一個函數(shù)聲明。

然而函數(shù)聲明是無法直接調(diào)用的,所以下面的寫法會導致錯誤:

function foo() {
  console.log('I am a function'); // Uncaught SyntaxError: Unexpected token ')'
}();

我們來分析一下,上面這段代碼,javascript解釋器會將其解釋為一個函數(shù)聲明,和一個分組操作符(()), 分組操作符是用來改變運算符優(yōu)先級的,里面必須有表達式才行,所以javascript解釋器會報錯。

那我們就給它一個表達式:

function foo() {
  console.log('I am a function'); // Uncaught SyntaxError: Unexpected token ')'
}(1);

這回代碼不報錯了,但是這段代碼毫無意義,這個函數(shù)并沒有執(zhí)行,實際上這段代碼與下面的代碼等價:

function foo() {
  console.log('I am a function');
}
(1);

它的返回值就是1,這不是我們想要的結(jié)果,我們需要函數(shù)定義后能立即被執(zhí)行,那就需要我們告訴javascript解釋器,這個函數(shù)是一個表達式,而不是一個聲明,因為表達式可以立即執(zhí)行,但是聲明不能。

而在javascript中,生成表達式最簡單的方式就是用()包裹起來,于是有了下面的代碼

(function foo() {
  console.log('I am a function');
});

這樣函數(shù)聲明就變成了一個函數(shù)表達式,但是這個表達式?jīng)]有名字,我們沒法調(diào)用它,我們先給它一個名字,然后通過名字調(diào)用它。

const bar = (function foo() {
  console.log('I am a function');
});
bar(); // I am a function

這樣完全沒有問題,但是這里的bar實在有點多余,實際上bar

(function foo() {
  console.log('I am a function');
});

是等價的,既然bar()可以調(diào)用函數(shù),那么我們直接在函數(shù)表達式末尾加上(),也可以調(diào)用這個函數(shù),于是就有了下面的代碼,這就是IIFE的由來。

(function foo() {
  console.log('I am a function');
})();

()寫在外層的括號內(nèi)也一樣,這種方式頗得javascript專家Douglas Crockford的青睞。我本人更喜歡第一種。

(function() {
  console.log('I am a function');
}());

IIFE的變種

由上面介紹可知,生成IIFE的精髓就是將函數(shù)聲明變成函數(shù)表達式,而在javascript中,生成表達式可不止使用()包裹起來這一種方式,還有很多其他的方式可以實現(xiàn)。于是IIFE也就是產(chǎn)生了諸多變種。

這個變種利用賦值運算符=來實現(xiàn),賦值運算符是將右側(cè)表達式的值賦值給左側(cè)變量的,所以它右側(cè)的部分被解析成了函數(shù)表達式及其調(diào)用。

const i = function() {
  console.log('I am an IIFE');
}();

下面的表中使用邏輯運算符來生成表達式。

true & (function() {
  console.log('I am an IIFE');
}());

還有下面這些,都是利用一元運算符來生成函數(shù)表達式。

!function(){ /* code */ }();
~function(){ /* code */ }();
-function(){ /* code */ }();
+function(){ /* code */ }();

最后來一個不為人知的,void運算符會對其右側(cè)的表達是求值然后返回undefined。(void expression - 先對expression求值,然后返回undefined)。

void function() {
  console.log('I am an IIFE');
}();

還有使用new運算符來生成IIFE,這種方式比較少見,因為它會創(chuàng)建一個新的對象。

new function() {
  console.log('I am an IIFE');
}();

這些方式都比較偏門了,不建議使用,只是用來幫助我們理解IIFE的。

為什么Self-Executing Anonymous Function這個名字不好?

Ben Alman認為這個名字有兩個問題:

Self-Executing:這個名字暗示函數(shù)會調(diào)用自己,但是實際上函數(shù)是立即被執(zhí)行的,而不是調(diào)用它自身。
比如下面的幾段代碼都會調(diào)用自己,但是這并不是IIFE的語義。

// 遞歸調(diào)用自身
function foo() { foo(); 
// 使用arguments.callee調(diào)用自身
const foo = function() { arguments.callee(); };

Anonymous:這個名字暗示函數(shù)是匿名的,但實際上函數(shù)可以有名字,也可以沒有名字,比如下面的例子:

// 有名字的IIFE
(function foo() {
  console.log('I am an IIFE');
})();

轉(zhuǎn)自https://www.cnblogs.com/graphics/p/18959048


該文章在 2025/7/3 9:12:40 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務(wù)費用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務(wù)都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved