av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

JavaScript的作用域鏈是在函數定義時確定還是在調用時?

瀏覽:109日期:2023-04-01 14:03:35

問題描述

看到如下的一個閉包問題

var x=10;function fn() { console.log(x);}function show(f) { var x=20; (function() {f(); })();}show(fn);

打印的是10而不是20,x在取值時不是沿著作用域鏈向上尋找嗎,如果作用域鏈是在函數創建時確定結果就是10,如果是在調用時確定就應該是20,有沒有關于作用域鏈準確的說法?這里準確的作用域鏈應該是什么樣的?fn和show處于同一級還是fn在show內?

問題解答

回答1:

作用域鏈是在函數定義的時候確定的.

在函數內定義的變量不能在函數之外的任何地方訪問,因為變量僅僅在該函數的域的內部有定義。相對應的,一個函數可以訪問定義在其范圍內的任何變量和函數。換言之,定義在全局域中的函數可以訪問所有定義在全局域中的變量。在另一個函數中定義的函數也可以訪問在其父函數中定義的所有變量和父函數有權訪問的任何其他變量。

https://developer.mozilla.org...

回答2:

作用域鏈是動態的,所以,在調用時確定。但是你的這個代碼中,閉包定義的function()是綁定的最外層的作用域function所申明的函數默認是綁定的外層的作用域

(我也是在學習中。。。)

回答3:

在函數創建的時候創建一個包含全局變量對象的作用域鏈,儲存在內部[[Scope]]屬性中。函數執行的時候會創建一個執行環境,通過復制[[Scope]]屬性中的對象,構建執行環境的作用域鏈,并把自己的活動對象推入該作用域鏈的前端以此形成完整的作用域鏈。[[Scope]]保存的是對全局變量的引用,而不是值的復制。

var a = 10;function f(){ console.log(a);};function foo(){ a = 20; f();};foo() // 20;回答4:

閉包的調用方式和下面效果等價的,下面舉得例子通過對比說明了,作用域鏈是和函數定義時位置相關的。

var x=10;function fn(){ console.log(x);}function show() { var x=20; fn();}show(); //輸出10-----------------------var x=10;function show() { var x=20; function fn(){console.log(x); } fn();}show(); //輸出20

相關問題鏈接補充。/q/10...。有關于作用域鏈的討論。

回答5:

非嚴格模式任何IIFE的this指向都是window

以上文不對題。。。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产成人精品网站 | av片在线观看 | 久久免费高清视频 | 91精品麻豆 | 黄色片视频 | 日本加勒比在线观看 | 中文字幕丰满人伦在线 | 四虎8848精品成人免费网站 | 日本色视频 | 欧美日本在线 | 超碰在线观看免费 | 性史性dvd影片农村毛片 | 特级丰满少妇一级aaaa爱毛片 | 久久精品一区二区 | 日韩在线免费观看视频 | 国产精品日韩欧美 | 国产黄a三级三级三级看三级男男 | 亚洲成人动漫在线观看 | av资源站 | 91精选视频 | 99在线播放 | 日韩毛片网 | 日韩在线观看中文字幕 | 日韩视频免费在线观看 | 国产自在线 | 亚洲精品视频在线 | a在线播放 | 欧美精品网站 | av免费在线观看网站 | 色婷婷在线播放 | 欧美一区二区三区在线观看 | 久久一区| 精品一区二区三区免费毛片 | 日本免费毛片 | 国产自在线 | 一区久久| 中文字幕日韩高清 | 不卡av在线 | 亚洲国产一区在线 | 亚洲视频免费在线观看 | 中文字幕精品在线 |