消除Javascript语法的一些不合理、不严谨之处,减小一些意外状况出现;
消除代码运行的一些不安全之处,保证代码运行的安全;
提升编译器效率,增长运行速度;
注意,一样的代码,在"严格模式"中,可能会有不同的运行结果;一些在"正常模式"下能够运行的语句,在"严格模式"下将不能运行。html
"use strict"; x = 3.14; // 报错 (x 未定义) "use strict"; x = {p1:10, p2:20}; // 报错 (x 未定义)
"use strict"; var x = 3.14; delete x; // 报错
"use strict"; function x(p1, p2) {}; delete x; // 报错
"use strict"; function x(p1, p1) {}; // 报错
"use strict"; var x = 010; // 报错
"use strict"; var x = \010; // 报错
"use strict"; var obj = {}; Object.defineProperty(obj, "x", {value:0, writable:false}); obj.x = 3.14; // 报错
"use strict"; var obj = {get x() {return 0} }; obj.x = 3.14; // 报错
"use strict"; delete Object.prototype; // 报错
"use strict"; var eval = 3.14; // 报错
"use strict"; var arguments = 3.14; // 报错
"use strict"; with (Math){x = cos(2)}; // 报错
"use strict"; eval ("var x = 2"); alert (x); // 报错
function f(){ return !this; } // 返回false,由于"this"指向全局对象,"!this"就是false function f(){ "use strict"; return !this; } // 返回true,由于严格模式下,this的值为undefined,因此"!this"为true。 所以,使用构造函数时,若是忘了加new,this再也不指向全局对象,而是报错。 function f(){ "use strict"; this.a = 1; }; f();// 报错,this未定义
为了向未来Javascript的新版本过渡,严格模式新增了一些保留关键字:安全
implements interface let package private protected public static yield "use strict"; var public = 1500; // 报错
更多信息参考:菜鸟教程函数