手册

目录

严格模式

收藏544

阅读599

更新时间2025-08-07

"use strict" 指令

"use strict" 是 JavaScript 1.8.5 中的新指令(ECMAScript version 5)。

它不算一条语句,而是一段文字表达式,更早版本的 JavaScript 会忽略它。

"use strict"; 的作用是指示 JavaScript 代码应该以“严格模式”执行。

在严格模式中,您无法,例如,使用未声明的变量。

以下版本的浏览器支持严格模式:

  • 版本 10 以后的 IE
  • 版本 4 以后的 Firefox
  • 版本 13 以后的 Chrome
  • 版本 5.1 以后的 Safari
  • 版本 12 以后的 Opera

声明严格模式

通过在脚本或函数的开头添加 "use strict"; 来声明严格模式。

在脚本开头进行声明,拥有全局作用域(脚本中的所有代码均以严格模式来执行):

实例

"use strict";
x = 3.14;       // 这会引发错误,因为 x 尚未声明
运行实例 »

点击 "运行实例" 按钮查看在线实例

实例

"use strict";
myFunction();

function myFunction() {
     y = 3.14;   // 这会引发错误,因为 y 尚未声明
}
运行实例 »

点击 "运行实例" 按钮查看在线实例

在函数中声明严格模式,拥有局部作用域(只有函数中的代码以严格模式执行):

x = 3.14;       // 这不会引发错误
myFunction();

function  myFunction() {
	"use strict";
	 y = 3.14;   // 这会引发错误
}
运行实例 »

点击 "运行实例" 按钮查看在线实例

"use strict"; 语法

声明严格模式的语法被设计为兼容更早版本的 JavaScript。

编译 JavaScript 程序中的数值文字(比如 4+5)或字符串文字("Bill Gates")不会有负面效果。它只会编译为不存在的变量然后消失。

所有 "use strict"; 只会对“理解”其含义的新编译器产生影响。

为什么使用严格模式?

严格模式使我们更容易编写“安全的” JavaScript。

严格模式把之前可接受的“坏语法”转变为真实的错误。

举例来说,在普通的 JavaScript 中,错打变量名会创建新的全局变量。在严格模式中,此举将抛出错误,这样就不可能意外创建全局变量。

在普通 JavaScript 中,如果向不可写属性赋值,开发者不会得到任何错误反馈。

在严格模式中,向不可写的、只能读取的、不存在的属性赋值,或者向不存在的变量或对象赋值,将抛出错误。

严格模式中不允许的事项

在不声明变量的情况下使用变量,是不允许的:

"use strict";
x = 3.14;                // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

对象也是变量

在不声明对象的情况下使用对象也是不允许的:

"use strict";
x = {p1:10, p2:20};      // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

删除变量(或对象)是不允许的:

"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; // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

字符串 "eval" 不可用作变量:

"use strict";
var eval = 3.14;         // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

字符串 "arguments" 不可用作变量:

"use strict";
var arguments = 3.14;    // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

with 语句是不允许的:

"use strict";
with (Math){x = cos(2)}; // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

处于安全考虑,不允许 eval() 在其被调用的作用域中创建变量:

"use strict";
eval ("var x = 2");
alert (x);               // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

在类似 f() 的函数调用中,this 的值是全局对象。在严格模式中,现在它成为了 undefined

对未来的保障

严格模式中不允许使用为未来预留的关键词。它们是:

  • implements
  • interface
  • let
  • package
  • private
  • protected
  • public
  • static
  • yield
"use strict";
var public = 1500;      // 这将引发错误
运行实例 »

点击 "运行实例" 按钮查看在线实例

警告

"use strict" 指令只能在脚本或函数的开头被识别。

相关

视频

RELATED VIDEOS

更多

免费

Web前端开发极速入门
初级 Web前端开发极速入门

219920次学习

收藏

免费

前端入门_HTML5
初级 前端入门_HTML5

616946次学习

收藏

免费

30分钟学会网站布局
初级 30分钟学会网站布局

238440次学习

收藏

免费

CSS视频教程-玉女心经版
初级 CSS视频教程-玉女心经版

393054次学习

收藏

免费

独孤九贱(1)_HTML5视频教程

免费

独孤九贱(6)_jQuery视频教程

免费

独孤九贱(7)_Bootstrap视频教程

免费

独孤九贱(2)_CSS视频教程
初级 独孤九贱(2)_CSS视频教程

229605次学习

收藏

科技资讯

更多

精选课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时

61.7万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时

39.3万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时

70.9万人学习

独孤九贱(1)_HTML5视频教程
独孤九贱(1)_HTML5视频教程

共25课时

61.6万人学习

独孤九贱(2)_CSS视频教程
独孤九贱(2)_CSS视频教程

共22课时

23万人学习

独孤九贱(3)_JavaScript视频教程
独孤九贱(3)_JavaScript视频教程

共28课时

33.9万人学习

独孤九贱(4)_PHP视频教程
独孤九贱(4)_PHP视频教程

共89课时

125万人学习

关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号