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进入“严格模式”,变量必须显式声明!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值