javascript - 關(guān)于具名的IIFE內(nèi)部對函數(shù)自身再賦值問題?
問題描述
+function foo(){foo=10;//我的問題代碼 console.log(foo);//方法自己}();console.log(typeof foo);//undefined 觀察是否全局污染
我想問 函數(shù)foo內(nèi)部對foo再賦值的這個(gè)10去哪了,還有同名函數(shù)foo是如何阻止全局污染的,求解求擴(kuò)展
問題解答
回答1:題主能問這個(gè),可以的.不過這題能通過自己實(shí)踐解決掉...
首先題主對于IIFE的寫法沒問題,IIFE的寫法好多,常見的就是@ewind說的這個(gè)和:
(function(){}())
還有不常見的:
!function(){ /* code */ }();~function(){ /* code */ }();-function(){ /* code */ }();+function(){ /* code */ }();
然后再說代碼:在函數(shù)里給當(dāng)前函數(shù)名賦值時(shí):foo = 10; 無效.(贊同@ewind,這里會忽略,應(yīng)該有更合理的說法.)JS解析器會忽略掉它.我在Chrome控制臺執(zhí)行的結(jié)果是:
function foo(){ foo=10;//我的問題代碼 console.log(foo);//方法自己}undefined// 上面typeof foo的結(jié)果
這就證明了上面我說的忽略.然后因?yàn)镮IFE模擬了塊作用域,外部環(huán)境訪問不了內(nèi)部的變量.所以就是undefined.
@ewind說因?yàn)閒oo是匿名函數(shù)然后怎樣怎樣.明顯概念搞混了.foo函數(shù)并不是匿名函數(shù).
function [name]([param] [, param] [..., param]) { statements }name函數(shù)名,可以省略。當(dāng)省略函數(shù)名的時(shí)候,該函數(shù)就成為了匿名函數(shù)。
MDN
回答2:首先,貼出的代碼是不完整的。完整版應(yīng)該是這樣
(function foo(){ foo = 10 console.log(foo) // [Function: foo]})();console.log(typeof foo) // undefined
這確實(shí)看起來比較反直覺,因?yàn)闆]有采用 var 聲明的 foo 并沒有污染全局作用域。
但如果函數(shù)內(nèi)聲明的變量名不是 foo,就很符合直覺了,如下:
var bar = 1;(function foo(){ bar = 10})();console.log(typeof foo) // undefinedconsole.log(bar) // 10
所以為什么函數(shù)內(nèi)聲明的變量和函數(shù)名同名時(shí),會發(fā)生問題呢?可以看這個(gè)示例:
(function foo(){ console.log(foo) // [Function: foo] console.log(arguments.callee) // [Function: foo] console.log(foo === arguments.callee) // true})();
在立即執(zhí)行的函數(shù)帶有 foo 這一函數(shù)名后,調(diào)用時(shí)的 arguments.callee 其實(shí)就是對 foo 的引用了。比較二者可以發(fā)現(xiàn)此時(shí) foo 就是函數(shù)對象。此時(shí)賦值操作并不能生效,遇到未加 var 聲明的 foo 變量時(shí),解釋器查找到的也是這個(gè)函數(shù)對象,從而不會在全局作用域下產(chǎn)生污染。
相關(guān)文章:
1. javascript - immutable配合react提升性能?2. javascript - sublime快鍵鍵問題3. css - 寫頁面遇到個(gè)布局問題,求大佬們幫解答,在線等,急!~4. 配置Apache時(shí),添加對PHP的支持時(shí)語法錯(cuò)誤5. phpstudy8.1支持win11系統(tǒng)嗎?6. javascript - nodejs關(guān)于進(jìn)程間發(fā)送句柄的一點(diǎn)疑問7. javascript - 移動(dòng)端上不能實(shí)現(xiàn)拖拽布局嗎?8. 實(shí)現(xiàn)bing搜索工具urlAPI提交9. Apache 已經(jīng)把網(wǎng)站根目錄的改為allow from all了,但是服務(wù)器還是不能訪問?10. vue.js - Vue 如何像Angular.js watch 一樣監(jiān)聽數(shù)據(jù)變化

網(wǎng)公網(wǎng)安備