JavaScript面向对象作用域
Posted 陈富康
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript面向对象作用域相关的知识,希望对你有一定的参考价值。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>作用域</title>
<script type="text/javascript" >
var add = function(){
num = 50;
}
add();
document.write(num);
</script>
</head>
<body>
</body>
</html>
运行结果如下:
我们发现50被运行出来了:为什么呢?
这是因为:
在这个函数的函数体中的赋值语句。这里将变量num前面的var拿掉了。如此一来,在整个程序中,num 都没有声明。对于一个没有声明的变量,
在第一次对它执行赋值操作时(函数运行时),它会自动的被添加到全局作用域(global scope)中,而不论这个赋值语句所在的作用域是哪个。乍一看
这个效果好像很强大,但实际上这是一种非常不好的编程实践。因为一般来说很少会出现有意忽略这个关键词的。这种情况下,可能会给其他的代码
阅读者造成困惑,他们可能会直接认为你犯了个错。
但是,如果js文件中第一行代码引入"use strict",也就是JavaScript进入“严格模式”,变量必须显式声明!
以上是关于JavaScript面向对象作用域的主要内容,如果未能解决你的问题,请参考以下文章