javascript中的严格模式

概述

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语句内为一个单独的作用域

你可能感兴趣的:(javascript)