0

0

javascript的严格模式有什么用_如何避免常见的编码陷阱【教程】

幻影之瞳

幻影之瞳

发布时间:2026-01-16 18:52:02

|

578人浏览过

|

来源于php中文网

原创

严格模式仅在"use strict"声明的作用域内生效,必须位于脚本顶部或函数体首行(允许空行和纯注释);它禁止隐式创建全局变量、参数重名、with语句,使非对象调用时this为undefined,并禁用delete不可配置属性及eval/arguments重赋值;es模块默认启用严格模式。

javascript的严格模式有什么用_如何避免常见的编码陷阱【教程】

严格模式会让 "use strict" 生效,但只在它声明的作用域内起作用

严格模式不是全局开关,"use strict" 必须出现在脚本顶部或函数体开头(且前面不能有可执行语句),否则会被忽略。常见错误是把它写在 if 分支里、注释后、或函数中间:

  • if (true) { "use strict"; } —— 完全无效,严格模式不进入任何作用域
  • console.log('hi'); "use strict"; —— 无效,必须是脚本/函数的**第一条语句**(允许前置空行和纯注释)
  • function foo() { console.log(1); "use strict"; } —— 无效,不是函数体第一行

正确写法只有两种:

"use strict";
// 全局严格模式
function foo() {
  "use strict";
  // 函数级严格模式
}

严格模式禁止隐式创建全局变量,强制暴露未声明变量错误

非严格模式下,foo = 42 会悄悄在全局对象(如 window)上挂一个属性;严格模式下直接抛出 ReferenceError: foo is not defined。这是最值得启用严格模式的原因之一——避免污染全局、掩盖拼写错误。

  • 漏写 var/let/const 时,严格模式立刻报错,而非静默失败
  • 函数参数名重复会报 SyntaxErrorfunction bar(a, a) {} 在严格模式下非法
  • with 语句被完全禁用,因为它会导致作用域链模糊、性能差且难以静态分析

严格模式让 this 在非对象调用中保持 undefined,而不是自动绑定到全局对象

非严格模式下,function foo() { return this; } 单独调用时返回 window浏览器)或 global(Node.js);严格模式下返回 undefined。这能提前暴露 this 绑定错误,尤其在回调、事件处理器或解构赋值后直接调用函数时:

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

Designs.ai
Designs.ai

AI设计工具

下载
function logName() {
  "use strict";
  console.log(this.name);
}
const obj = { name: "Alice" };
logName(); // this === undefined → 输出 undefined,不会意外读取 window.name

注意:箭头函数本身不改变 this 行为,它的 this 始终继承外层,与严格模式无关。

严格模式下禁止删除不可配置属性,也禁止对 evalarguments 重新赋值

这些限制看似琐碎,实则堵住了几类隐蔽陷阱:

  • delete Object.prototype.toString 在严格模式下抛 TypeError,防止破坏原型链
  • eval = 42arguments = [] 会立即报 SyntaxError,避免覆盖语言内置标识符
  • 函数内部无法用 arguments.callee 实现递归(已被废弃),倒逼你使用命名函数表达式

现代开发中,eval 本身应尽量避免;而 arguments 的替代方案是剩余参数 ...args,更安全、更易优化。

严格模式不是银弹,但它把很多“运行时靠运气”的行为变成“编译/执行期就报错”。真正容易被忽略的是:模块(.mjstype="module" 的 script)**默认启用严格模式**,无需写 "use strict" —— 这意味着你在写 ES 模块时已经享受了大部分好处,但若混用 script 标签加载的普通 JS 文件,仍需手动声明。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

839

2023.08.22

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

313

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

290

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

174

2025.08.07

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

557

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

87

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

105

2025.09.18

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

2

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.7万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

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

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