JS学习(15)严格模式

203 阅读5分钟

前言

  • use strict是什么意思?使用它区别是什么?

什么是严格模式

严格模式是从ES5开始新增的一种方式,是采用具有限制性Javasaript变体的一种方式,从而使代码隐式地脱离"马虎模式/稀松模式/懒散模式"(sloppy)模式。

设立严格模式的目的如下:

  • 消除 Javascript 语法的不合理、不严谨之处,减少怪异行为;
  • 消除代码运行的不安全之处,保证代码运行的安全;
  • 提高编译器效率,增加运行速度;
  • 为未来新版本的 Javascript 做好铺垫。

"严格模式"体现了Javascript更合理、更安全、更严谨的发展方向,支持严格模式的浏览器有:Internet Explorer10+、Firefox4+ Chrome 13+、Safari 5.1+、Opera12+。

在"严格模式下",同样的代码,可能会有不一样的运行结果。一些在"正常模式"下可以运行的语句,在"严格模式"下将不能运行。

开启严格模式

进入"严格模式"的标志,是下面这行语句:

"use strict";

老版本的浏览器会把它当作一行普通字符串,加以忽略。

"严格模式"有两种调用方法,适用于不同的场合。

针对整个脚本文件

将"use strict"放在脚本文件的第一行,则整个脚本都将以"严格模式"运行。

如果这行语句不在第一行,则无效,整个脚本以"正常模式"运行。如果不同模式的代码文件合并成一个文件,这一点需要特别注意。

"use strict";
function doSomething() {
}

针对单个函数

将"use strict"放在函数体的第一行,则整个函数以"严格模式"运行。

function doSomething() {
  "use strict";
  // 函数体
}

脚本文件的变通写法

因为第一种调用方法不利于文件合并,所以更好的做法是,借用第二种方法,将整个脚本文件放在一个立即执行的匿名函数之中。

(function() {
  "use strict";
  // 在这里编写代码
})()

严格模式与普通模式的区别

  1. 没有使用var声明的变量不能使用

在普通模式下,我们可以使用一个未声明的变量,此时该变量会成为一个全局变量。但是这种使用方式在严格模式下会报错。

"use strict";
x = 1; // 报错,x未声明
  1. 删除变量和不可删除的属性会报错

在普通模式下,删除变量或者不可删除的属性虽然也会失败,但是是"静默失败",也就是说虽然失败了,但是不会给出任何提示。这样其实会产生很多隐藏问题,也给程序员的调错带来了难度。

"use strict";
var a = 1;
delete a;
  1. 函数中相同的参数名会报错

在普通模式下,函数中两个形参名相同也不会报错,只不过后面的形参所接收到的值会覆盖前面的同名形参。

"use strict";
function x(p1, p1) {}; // 抛出错误
  1. 对象不能有重复的属性名(根据MDN的说法,ES6已经不复存在,有bug提案)

正常模式下,如果对象有多个重名属性,最后赋值的那个属性会覆盖前面的值。严格模式下,这属于语法错误。

"use strict";
var obj = {
  p: 1,
  p: 2
}; // 报错

screenshot-20240726-172138.png

  1. 禁止八进制数字表示法

在普通模式下,八进制数字表示法以0开头,会被当作8进制处理。严格模式禁止这种表示法,会报错。

"use strict";
var sum =
  015 + // !!! 语法错误
  197 +
  142;
  1. 函数内部的this为undefined

在普通模式下,函数中的this在以函数的形式被调用时,指向全局对象。而在严格模式中,得到的值为undefined。

"use strict";
function f(){
  return this;
}
f() === undefined; // true
  1. 创设eval作用域

正常模式下,Javascript语言有两种变量作用域(scope):全局作月用域和函数作用域

严格模式创设了第三种作用域:eval作用域。

正常模式下,eval语句的作用域,取决于它处于全局作用域,还是处于函数作用域。

严格模式下,eval语句本身就是一个作用域,不再能够生成全局变量了,它所生成的变量只能用于eval内部。

"use strict";
var x = 2;
console.log(eval("var x = 5; x")); // 5
console.log(x); // 2
  1. 保留字

为了向将来Javascript的新版本过渡,严格模式新增了一些保留字:implements, interface, let, package, private,protected,public,static,yield。使用这些词作为变量名将会报错。

"use strict";
var let = 1;

更多参考developer.mozilla.org/zh-CN/docs/…

总结

  • use strict是什么意思?使用它区别是什么?

use strict 代表开启严格模式,这种模式使得javascript在更严格的条件下运行,实行更严格解析和错误处理。

设立严格模式的目的如下:

  • 消除 Javascript 语法的不合理、不严谨之处,减少怪异行为;
  • 消除代码运行的不安全之处,保证代码运行的安全;
  • 提高编译器效率,增加运行速度;
  • 为未来新版本的 Javascript 做好铺垫。

严格模式与普通模式的区别:

  • 没有使用var声明的变量不能使用
  • 删除变量和不可删除的属性会报错
  • 函数中相同的参数名会报错
  • 对象不能有重复的属性名(根据MDN的说法,ES6已经不复存在,有bug提案)
  • 禁止八进制数字表示法
  • 函数内部的this为undefined
  • 创设eval作用域
  • 保留字