Java教程

JavaScript面向对象作用域

本文主要是介绍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面向对象作用域的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!