JS严格模式(use strict)

ECMAscript5 新增了严格运行模式。推出严格模式的目的如下:

  • 消除 JavaScript 语法中不合理、不严谨的用法。
  • 消除代码运行的一些安全隐患。
  • 提高编译器效率,提升程序运行速度。
  • 为未来新版本的规范化做好铺垫。

启用严格模式

在代码首部添加以下一行字符串,即可启用严格模式。

  1. "use strict"

不支持严格模式的浏览器会把它作为字符串直接量忽略掉。

首部就是指其前面没有任何有效的 JavaScript 代码。例如,以下用法都不会触发严格模式。

1) “use strict” 前有可执行的代码:

  1. var width = 10;
  2. 'use strict'; /*无效的严格模式*/
  3. globalVar = 100;

2) “use strict” 前有空语句:

  1. ;
  2. 'use strict'; /*无效的严格模式*/
  3. globalVar = 100;

或者:

  1. ;'use strict1'; /*无效的严格模式*/
  2. globalVar = 100;

注释语句不作为有效的 JavaScript 代码。例如,下面用法会触发严格模式。

  1. //严格模式
  2. 'use strict'; /*有效的严格模式*/
  3. globalVar = 100;

因此,只要前面没有会产生实际运行结果的语句,”use strict” 就可以不在第一行。

严格模式的应用场景

严格模式有两种应用场景,简单说明如下。

全局模式

将 “use strict” 放在脚本文件的第一行,则整个脚本都将以严格模式运行。如果不在第一行,则整个脚本将以正常模式运行。

下面示例在页面中添加两个 JavaScript 代码块,第一个代码块将开启严格模式,第二个代码块将按正常模式解析。

  1. <script>
  2. "use strict";
  3. console.log("这是严格模式。");
  4. </script>
  5. <script>
  6. console.log("这是正常模式。");
  7. </script>

局部模式

将 “use strict” 放在函数内首部,则整个函数将以严格模式运行。

下面示例定义了两个函数,其中第一个函数开启了严格模式,第二个函数按正常模式运行。

  1. function strict(){
  2. "use strict";
  3. return "这是严格模式。";
  4. }
  5. function notStrict(){
  6. return "这是正常模式。";
  7. }

全局模式不利于 JavaScript 文件合并。例如,如果一个开启了严格模式的 JavaScript 库,被导入到一个正常模式的网页脚本中,由于无法确保 “use strict” 位于脚本的首部位置,容易导致严格模式失效。因此,推荐的最佳实践是使用局部模式,将整个 JavaScript 文件脚本放在一个立即执行的匿名函数中,在匿名函数内启动严格模式。当 JavaScript 库文件被导入到不同模式的网页中,就不用担心严格模式失效了。

  1. (function(){
  2. "use strict";
  3. // JavaScript库文件 代码
  4. }) ();

严格模式的执行限制

严格模式对 JavaScript 的语法和行为有着严格的限制。对于初学 JavaScript 语言的读者来说,应该养成好的习惯。例如,变量必须先声明后使用,否则会抛出语法错误。

示例

执行下面代码,将会提示语法错误。因此,必须先用 var 语句声明,然后再使用。

  1. "use strict"; //开启严格模式
  2. v = 1; //报错,v未声明
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智慧浩海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值