什么是严格模式_JavaScript中如何启用严格模式

发布时间 - 2026-01-05 00:00:00    点击率:
严格模式是JavaScript的限制性变体,通过“use strict”启用,提升代码安全性与可预测性;脚本顶层需首行声明,函数内可局部启用,ES模块默认启用而CommonJS需手动添加。

严格模式(Strict Mode)是 JavaScript 的一种限制性变体,启用后会让引擎以更严格的规则解析和执行代码,提前暴露潜在错误、禁用不安全或易混淆的语法,并为未来语言演进铺路。它不是新语言,而是现有语法的“增强校验层”。

如何在脚本顶层启用严格模式

.js 文件或 标签的最开头(不能有前置语句或注释)插入字符串字面量 "use strict";

"use strict";
console.log(this); // 全局作用域下 this 为 undefined,而非 globalThis

注意:"use strict" 必须是脚本第一行可执行内容;若前面有空行、// 注释或 /* */ 注释(即使为空),仍可生效;但若有 var x = 1;import 等语句,则失效。

如何在函数作用域启用严格模式

只对单个函数启用严格模式,不影响外部代码,适合渐进式迁移:

立即学习“Java免费学习笔记(深入)”;

function foo() {
  "use strict";
  delete arguments; // 报错:严格模式下禁止删除 arguments / callee
  with ({ x: 1 }) {} // 报错:严格模式禁止使用 with 语句
}
  • "use strict" 必须位于函数体第一行(允许前面有换行或块注释)
  • 箭头函数不能直接启用严格模式,需依赖外层函数或脚本级声明
  • 严格模式状态不会被 eval() 继承,除非 eval 内部也写 "use strict"

严格模式下典型行为变化与常见报错

启用后以下操作会直接抛出 TypeErrorSyntaxError,而非静默失败:

  • 给只读属性赋值:Object.defineProperty(obj, 'x', { value: 1, writable: false }); obj.x = 2; → 报错
  • 删除不可配置属性:delete Object.prototype; → 报错
  • 使用八进制字面量:010SyntaxError(ES5 严格模式禁止隐式八进制)
  • 函数参数重名:function f(a, a) { }SyntaxError
  • this 在非对象调用中为 undefined,而非自动绑定到全局对象

这些限制让代码更可预测,也更容易被现代 JS 引擎优化。

模块(ESM)默认就是严格模式

所有 import/export 语法的文件(即 ES 模块)无需显式声明,自动启用严格模式:

// math.js
export function add(a, b) {
  arguments.callee; // ReferenceError:严格模式下 callee 不可用
  return a + b;
}

这意味着:如果你用 type="module" 加载脚本,或通过 import 引入,就已处于严格模式——不必再加 "use strict",加了也无害。

真正容易忽略的是:CommonJS(Node.js 的 require)模块默认不启用严格模式,必须手动加;而 ESM 下即使没写,也已生效。混合使用时尤其要注意行为差异。


# javascript  # java  # js  # node.js  # node  # 作用域 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在阿里云通过域名搭建网站?  如何快速查询网站的真实建站时间?  Android使用GridView实现日历的简单功能  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程  LinuxShell函数封装方法_脚本复用设计思路【教程】  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何快速搭建个人网站并优化SEO?  如何快速搭建高效WAP手机网站吸引移动用户?  油猴 教程,油猴搜脚本为什么会网页无法显示?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  linux写shell需要注意的问题(必看)  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  如何快速搭建二级域名独立网站?  如何在建站宝盒中设置产品搜索功能?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  香港网站服务器数量如何影响SEO优化效果?  如何在万网ECS上快速搭建专属网站?  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  如何获取上海专业网站定制建站电话?  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  PHP正则匹配日期和时间(时间戳转换)的实例代码  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  Python3.6正式版新特性预览  浅谈redis在项目中的应用  原生JS获取元素集合的子元素宽度实例  微信小程序 五星评分(包括半颗星评分)实例代码  Laravel Session怎么存储_Laravel Session驱动配置详解  Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  googleplay官方入口在哪里_Google Play官方商店快速入口指南  JS实现鼠标移上去显示图片或微信二维码  Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南  Android仿QQ列表左滑删除操作  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】  Laravel如何集成Inertia.js与Vue/React?(安装配置)  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  如何彻底删除建站之星生成的Banner?  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  Windows Hello人脸识别突然无法使用  如何挑选高效建站主机与优质域名?  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  BootStrap整体框架之基础布局组件  北京的网站制作公司有哪些,哪个视频网站最好?  如何用AI帮你把自己的生活经历写成一个有趣的故事?  七夕网站制作视频,七夕大促活动怎么报名?