什么是严格模式:
除了正常运行模式(混杂模式),ES5 添加了第二种运行模式:“严格模式”(strict mode)。
顾名思义,这种模式使得 Javascript 在更严格的语法条件下运行。
严格模式的作用:
- 消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为。
- 消除代码运行的一些不安全之处,保证代码运行的安全。
- 提高编译器效率,增加了运行速度。
- 为未来新版本的Javascript做好铺垫。
怎么开启严格模式:
在全局或函数的第一条语句定义为: ‘use strict’;
如果浏览器不支持, 只解析为一条简单的语句, 没有任何副作用。
<script type="text/javascript">
'use strict';
</script>
语法和行为改变:
1. 必须用var声明变量
正常模式下,变量没有声明就赋值,默认是全局变量,而严格模式下,会直接报错。必须用 var 声明变量。
var age = 12;
console.log(age);
2. 禁止自定义的函数中的this指向 window
正常模式下,在全局作用域中 this 指向 window 对象。构造函数不加 new 也可以调用。
严格模式下,在全局作用域中 this 指向 undefined。构造函数不加 new 调用,this 指向的undefind,如果给它赋值,会报错。
var fun = function () {
console.log(this);
}
fun();//undefined
function Person(name, age) {
this.name = name;
this.age = age;
}
new Person('kobe', 39);
console.log(name);
3. 创建eval作用域
正常模式下,js 有两种变量作用域:全局作用域和函数作用域。
严格模式下,会创建第三种作用域:eval 作用域。
严格模式下,eval 语句本身就是一个作用域,不能在其所运行的作用域设新的变量,也就是说,eval 所生成的变量只能用于eval内部。
var name = 'kobe';
eval('var name = "Tom";alert(name)'); //Tom
console.log(name); //kobe
4. 对象不能有重名的属性,函数不能有重名的参数
正常模式下,最后赋值的属性会覆盖前面的值;严格模式下属于语法错误。
普通模式下,如果函数有多个重名的参数,可以用 arguments[i] 读取;严格模式下,多个重名的参数属于语法错误。
var obj = {
name : 'kobe',
name : 'weide' //严格模式下属于语法错误
};
console.log(obj);