溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JavaScript中匿名函數(shù)與變量有什么用

發(fā)布時(shí)間:2021-08-07 10:07:56 來源:億速云 閱讀:215 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)JavaScript中匿名函數(shù)與變量有什么用,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

匿名函數(shù):沒有實(shí)際名字的函數(shù)。

匿名函數(shù)的作用:

1、通過匿名函數(shù)可以實(shí)現(xiàn)閉包,關(guān)于閉包在后面的文章中會(huì)重點(diǎn)講解。在這里簡(jiǎn)單介紹一下:閉包是可以訪問在函數(shù)作用域內(nèi)定義的變量的函數(shù)。若要?jiǎng)?chuàng)建一個(gè)閉包,往往都需要用到匿名函數(shù)。
2、模擬塊級(jí)作用域,減少全局變量。執(zhí)行完匿名函數(shù),存儲(chǔ)在內(nèi)存中相對(duì)應(yīng)的變量會(huì)被銷毀,從而節(jié)省內(nèi)存。再者,在大型多人開發(fā)的項(xiàng)目中,使用塊級(jí)作用域,會(huì)大大降低命名沖突的問題,從而避免產(chǎn)生災(zāi)難性的后果。自此開發(fā)者再也不必?fù)?dān)心搞亂全局作用域了。

具體內(nèi)容如下所示:

以前都是直接用前端框架Bootstrap,突然想看看Javascript,發(fā)現(xiàn)javascript是個(gè)非常有趣的東西,這里把剛碰到的一個(gè)小問題的理解做下筆錄

/**
 * Example 1
 */
var localvar = "local var";
console.log(localvar);//local var
/**
 * Example 2
 */
console.log(x === undefined); // true
var x = 3;
/**
 * Example 3
 */
var myvar = "my value";
//Test01
//will return a value of undefined
(function() {
 console.log(myvar); // undefined
 var myvar = "local value";
 console.log(myvar); // local value
})();
console.log(myvar);//my value
//Test02
(function myFunction(){
 console.log(myvar);//my value
})();
//Test03
var test = new function(){
 console.log(myvar);//my value
};

解釋如下:

(1).JavaScript 變量的特別之處是,你可以引用稍后聲明的變量而不會(huì)引發(fā)異常。這一概念稱為變量聲明提升(hoisting);

(2).JavaScript 變量感覺上是被“提升”或移到了函數(shù)或語句的頂部。然而提升后的變量將返回 undefined 值。

(3).在使用或引用某個(gè)變量之后進(jìn)行聲明和初始化操作,這個(gè)被提升的引用仍將得到 undefined 值。

(4).這里Example 3中Test01是這次問題的關(guān)鍵,Test01和Test02是很相似的(至少我看著很相似)。但是最后輸出結(jié)果不能用(1)、(2)、(3)來解釋

  經(jīng)過查看官方API文檔發(fā)現(xiàn),在匿名函數(shù)(function() {})();的使用中形成了閉包(重點(diǎn),不清楚的可以查閱閉包的概念,閉包概念還是好理解的);

  由于閉包的存在,全局變量自然無法訪問(閉包的一個(gè)重要原因就是為了避免訪問全局變量),故Test01 function中第一句輸出結(jié)果為undefined。

總結(jié)原因:匿名函數(shù)(function() {})();是一個(gè)特殊的閉包寫法。

關(guān)于“JavaScript中匿名函數(shù)與變量有什么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI