概述
ES5中规定了javascript的严格模式,通过在代码前加入'use strict';
,之后的代码便应用严格模式,这是对javascript进行规范化的一个重要改革。
差异
严格模式和非严格模式之间的差异,我分三个方面来论述:语法错误,新的运行错误,语义区别;
语法错误
以下语法会在代码运行时抛出错误“SyntaxError”
// 不能直接定义八进制数字
var n = 023;
// 不能用with声明
// 不能用delete语法删除一个var声明的变量
// 把eval或arguments不能作为var声明的变量名或者函数的参数名
// 增加了保留字(implements, interface, let, package, private, protected, public, static, yield)
// 函数不可以定义在流程控制语句内部
if (a < b) { function f() {} }
// 不能以字面量形式定义一个对象中属性名重复的属性,也不能定义一个函数中名称重复的参数
var n = {a: 1, b: 3, a: 7};
function f(a, b, b) {}
运行的新错误
// 不能给未定义的变量赋值
function f(x) {
'use strict';
var a = 12;
b = a + x * 35; // error!
}
f(42);
// 不能删除不可配置的属性
delete Object.prototype; // error!
// 不能使用arguments.caller和arguments.callee
语义区别
// 默认函数的this不指向window,而指向undefined
(function(){
'use strict';
console.log(this); // undefined
})()
// arguments不能修改,变为函数参数的静态副本,不再追踪参数的变化
(function(a){
'use strict';
arguments[0]=2;
console.log(a); // 1
})(1)
// eval语句内为一个单独的作用域