严格模式
JavaScript 除了提供正常模式外,还提供了严格模式(strictmode)。ES5 的严格模式是采用具有限制性JavaScript 变体的一种方式,即在严格的条件下运行JS 代码。严格模式在IE10 以上版本的浏览器中才会被支持,旧版本浏览器中会被忽略。严格模式对正常的JavaScript 语义做了一些更改:
1.消除了Javascript语法的一些不合理、不严谨之处,减少了一些怪异行为。【例如变量,不声明就报错】
2.消除代码运行的一些不安全之处,保证代码运行的安全。
3.提高编译器效率,增加运行速度。
4.禁用了在ECMAScript的未来版本中可能会定义的一些语法,为未来新版本的Javascript做好铺垫。比如一些保留字如:class, enum, export, extends, import, super 不能做变量名
开启严格模式
开启严格模式:“use strict”,就是在script标签里面的最前面写一句"use strict"就可以开启严格模式。严格模式可以应用到整个脚本或个别函数中。因此在使用时,我们可以将严格模式分为为脚本开启严格模式和为函数开启严格模式两种情况。
<script>
"use strict" //脚本开启严格模式
</script>
<script>
function fn () {
"use strict" //为函数开启严格模式
}
</script>
为脚本开启严格模式
//为整个脚本文件开启严格模式,需要在所有语句之前放一个特定语句“use strict”;(或‘use strict’;)。
<script>
"use strict";
console.log("这是严格模式。");
</script>
//因为"use strict"加了引号,所以老版本的浏览器会把它当作一行普通字符串而忽略。
为函数开启严格模式
要给某个函数开启严格模式,需要把“use strict”; (或'use strict'; ) 声明放在函数体所有语句之前。
function fn(){"use strict";return "这是严格模式。";}
将"use strict"放在函数体的第一行,则整个函数以"严格模式"运行。
严格模式中的变化
严格模式对Javascript的语法和行为,都做了一些改变。
变量规定
变量申明必须加var,而且不准删除变量
在正常模式中,如果一个变量没有声明就赋值,默认是全局变量。严格模式禁止这种用法,变量都必须先用var命令声明,然后再使用。严禁删除已经声明变量。例如,delete x; 语法是错误的。
严格模式下this 指向问题
严格模式下,普通函数this是undefined
以前在全局作用域函数中的this 指向window 对象。严格模式下全局作用域中函数中的this是undefined。
其他的没有变化:
以前构造函数时不加new也可以调用,当普通函数,this 指向全局对象。严格模式下,如果构造函数不加new调用, this 指向的是undefined 如果给他赋值则会报错。new 实例化的构造函数指向创建的对象实例。定时器this 还是指向window 。事件、对象还是指向调用者。
函数变化
参数不能重名
函数不能有重名的参数。
函数必须声明在顶层,新版本的JavaScript 会引入“块级作用域”(ES6 中已引入)。为了与新版本接轨,不允许在非函数的代码块内声明函数。【if,for等里面定义函数也不可以】。
错误写法:
function fn (a,a) {console.log(a+a);}
fn(1,2);
更多严格模式要求参考:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Strict_mode