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面向对象作用域的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript面向对象及相关知识

JavaScript面向对象作用域

javascript面向对象编程(OOP)——汇总

JavaScript 作用域 与 作用域链

JavaScript面向对象for(),while(),if()的作用域

JavaScript<面向对象Object>函数方法&对象创建&原型对象&作用域解析