Javascript 严格模式的一些理解
平常我们在ECMAscript5中可以声明以下的变量
num = 5;
console.log(num);//输出的是变量5
而为了Javascript更合理、更安全、更严谨的方向发展,添加了一种新的模式进来 - “严格模式”
严格模式的主要目的
1、消除javascript的一些不严谨、不合理之处,减少一些怪异的错误;
2、消除代码的一些不安全,保证代码的安全
3、提高编译效率,增加运行速度
4、为未来新版本的javascript做好铺垫
支持严格模式下的浏览器:Internet Explorer 10 +、 Firefox 4+ Chrome 13+、 Safari 5.1+、 Opera 12+
进入严格模式使用 “use strict”语句
老版本的浏览器会默认当成一串字符串执行
如果要以严格模式进行代码编译,需要把“use strict”写在脚本内的第一行
例1:
<script>
“use srtrict”; //这是一个严格模式的执行代码,写在脚本内的第一行
var num = 1;
console.log(num);
</script>
<script>
var num = 1; //这是正常模式
console.log(num);
</script>
严格模式也可以针对单个函数进行执行
例2:<script>
function strict (){
“use strict”;
return ‘这是严格模式’;
}
function notStrict (){
return ‘这是正常模式’;
}
</script>
可以将严格模式放在立即执行函数中
例3: (function(){
“use strict”;
})();
严格模式对Javascript的语法和行为,都做了一些改变
在正常模式中,如果一个变量没有生命便赋值,默认是全局变量 例如:a = 1; 严格模式中严禁这种写法,全局变量必须显示生命,添加var
例4: <script>
“use strict”;
i = 1;
for(i = 0; i < 2; i++) { // 报错,i声明错误
}
</script>
禁止this关键字指向全局对象
在普通函数下,this的指向是全局对象window,在严格模式下,this的值为undefined,所以在构造函数下
function f(){
"use strict";
this.a = 1;
};
f();// 报错,this未定义
严格模式下无法删除变量,只有将configurable设置为true
“use strict”;
var x;
delete x //报错,语法错误
var o = Object.create(null, {'x': {
value: 1,
configurable: true
}});
delete o.x; // 删除成功