Javascript中的作用域是如何工作的
How does scope in Javascript work?
我不明白Javascript中的作用域是如何工作的。
例如
<html>
<head>
<script>var userName = "George"; </script>
</head>
<body>
......
<script>
document.write('Name = ' + userName);
</script>
</body>
</html>
变量userName
在脚本的另一个"部分"中声明。据我所知,浏览器呈现html并按照找到它的顺序执行代码。那么第二个脚本标签中的userName
是如何解决的呢?是全局设置吗?我之前声明的任何东西都是全局的吗?
我注意到,如果我这样做,也会发生同样的情况:
<html>
<head>
<script>
do {
var userName = "George";
//bla
} while (someCondition);
</script>
</head>
<body>
......
<script>
document.write('Name = ' + userName);
</script>
</body>
</html>
即使userName
在{}
中声明,它仍然在第二个脚本中解析。这怎么可能呢?
Javascript作用域是按函数定义的(ECMAScript 6添加了let
语句,也引入了块作用域)。在函数定义或let
块中没有使用var
或function
声明的所有内容都在全局作用域中。只有一个全局作用域,由所有<script>
块共享。do
块没有引入新的作用域,因此在这里声明的变量在后面的document.write()
块中是可见的。
示例中唯一的作用域是全局作用域。不同的脚本块都是DOM元素,没有自己的javascript作用域
在本例中,您将在全局window
作用域中创建变量userName
。将第一个示例加载到浏览器后,打开JavaScript控制台并执行console.log(window)
操作。您应该看到将window
对象转储到控制台中。打开它,你会发现键"userName",值"George"。
当你下次从document.write
中引用变量userName
时,你是从全局作用域引用它的。
如果您编写了一个函数,然后从document.write()
调用它,那么您将不再在window
作用域中看到它,只要您使用var
关键字将它声明为函数的局部变量。
<html>
<head>
<script>
function foo() {
var userName = "George";
return 'Name = ' + userName;
}
</script>
</head>
<body>
......
<script>
document.write(foo());
</script>
</body>
</html>
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- 最大高度转换不;不工作,工作缓慢
- Gulp-rev:不是第一次工作,而是在第一次工作之后工作
- 在JavaScript中的类中,push和concat的工作方式有何不同
- JQuery - Ajax: encodeUriComponent不工作(EncodeUri工作)