登录
注册
开源
企业版
高校版
搜索
帮助中心
使用条款
关于我们
开源
企业版
高校版
私有云
模力方舟
AI 队友
登录
注册
Gitee 年度开源项目评选中~
代码拉取完成,页面将自动刷新
捐赠
捐赠前请先登录
取消
前往登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
Watch
不关注
关注所有动态
仅关注版本发行动态
关注但不提醒动态
3
Star
46
Fork
21
DreamCoders
/
CoderGuide
代码
Issues
1169
Pull Requests
0
Wiki
统计
流水线
服务
JavaDoc
PHPDoc
质量分析
Jenkins for Gitee
腾讯云托管
腾讯云 Serverless
悬镜安全
阿里云 SAE
Codeblitz
SBOM
我知道了,不再自动展开
更新失败,请稍后重试!
移除标识
内容风险标识
本任务被
标识为内容中包含有代码安全 Bug 、隐私泄露等敏感信息,仓库外成员不可访问
说说js 什么是严格模式,及严格模式的限制?
待办的
#IAG9OU
陌生人
拥有者
创建于
2024-07-29 16:07
<p style="text-align: justify;"><span style="font-size: 15px;">JavaScript的严格模式(Strict Mode)是一种在代码中启用的特殊模式,用于提供更严格的语法和错误检查,以改善代码质量和增强安全性。使用严格模式可以帮助大家避免一些常见的错误,并禁用一些不推荐使用的特性。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">要启用严格模式,可以在代码的顶部或函数体的开头添加以下语句:</span></p><pre><code class="language-javascript">"use strict";</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">启用严格模式后,会应用一些限制和变化,包括以下几个方面:</span></p><p style="text-align: justify;"><span style="font-size: 15px;">1. 变量必须先声明后使用:在严格模式下,变量必须通过 var、let 或 const 关键字进行声明,否则会抛出 ReferenceError。在非严格模式下,未声明的变量会被隐式创建,并被添加到全局对象(比如浏览器环境中的 window 对象)中。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">2. 禁止删除变量、函数或函数参数:在严格模式下,使用 delete 操作符删除变量、函数或函数参数会抛出 SyntaxError。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">3. 禁止对只读属性进行赋值:在严格模式下,对只读属性(通过 const 关键字声明的常量)进行赋值会抛出 TypeError。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">4. 禁止使用八进制字面量:在严格模式下,以 0 开头的数字会被视为八进制字面量,这在非严格模式下是允许的。严格模式下,使用八进制字面量会抛出 SyntaxError。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">5. 限制 this 值:在严格模式下,函数内部的 this 值不再是全局对象(比如浏览器环境中的 window 对象),而是undefined,除非通过 call()、apply() 或 bind() 明确指定。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">6. 禁止使用重复的函数参数名:在严格模式下,函数参数名不能重复。在非严格模式下,重复的函数参数名会被忽略。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">7. 禁止使用 with 语句:在严格模式下,使用 with 语句会抛出 SyntaxError。with 语句在非严格模式下允许将对象的属性添加到作用域链中,但这被认为是不推荐使用的特性,因为它可能导致代码可读性和性能问题。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">8. 限制 eval 和 arguments 的赋值:在严格模式下,无法对 eval 和 arguments 进行赋值。在非严格模式下,这种赋值是允许的。</span></p><p style="text-align: justify;"><br></p><p style="text-align: justify;"><span style="font-size: 15px;">下面是一些使用JavaScript严格模式的例子,展示了严格模式下的限制和行为变化:</span></p><p style="text-align: justify;"><span style="font-size: 15px;">1. 变量必须先声明后使用:</span></p><pre><code class="language-javascript">"use strict"; x = 10; // 抛出 ReferenceError: x is not defined</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,对未声明的变量进行赋值会抛出错误。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">2. 禁止删除变量:</span></p><pre><code class="language-javascript">"use strict"; var x = 10; delete x; // 抛出 SyntaxError: Delete of an unqualified identifier in strict mode.</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,无法使用 delete 操作符删除变量。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">3. 禁止对只读属性进行赋值:</span></p><pre><code class="language-javascript">"use strict"; var obj = {}; Object.defineProperty(obj, "x", { value: 10, writable: false }); obj.x = 20; // 抛出 TypeError: Cannot assign to read only property 'x' of object ' <Object>'</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,对只读属性进行赋值会抛出错误。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">4. 八进制字面量的限制:</span></p><pre><code class="language-javascript">"use strict"; var num = 012; // 抛出 SyntaxError: Octal literals are not allowed in strict mode.</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,使用八进制字面量会被视为语法错误。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">5. 函数中的 this 值为 undefined:</span></p><pre><code class="language-javascript">"use strict"; function showThis() { console.log(this); } showThis(); // undefined </code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,如果函数内部的 this 值未明确指定,它将保持为 undefined。</span><br><span style="font-size: 15px;">这些是严格模式下的一些限制和变化,它们有助于提高代码的可靠性和可维护性。在编写新代码或更新现有代码时,启用严格模式是一种良好的实践,可以帮助捕获潜在的错误并遵循更严格的编码标准。</span></p><p><br></p>
<p style="text-align: justify;"><span style="font-size: 15px;">JavaScript的严格模式(Strict Mode)是一种在代码中启用的特殊模式,用于提供更严格的语法和错误检查,以改善代码质量和增强安全性。使用严格模式可以帮助大家避免一些常见的错误,并禁用一些不推荐使用的特性。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">要启用严格模式,可以在代码的顶部或函数体的开头添加以下语句:</span></p><pre><code class="language-javascript">"use strict";</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">启用严格模式后,会应用一些限制和变化,包括以下几个方面:</span></p><p style="text-align: justify;"><span style="font-size: 15px;">1. 变量必须先声明后使用:在严格模式下,变量必须通过 var、let 或 const 关键字进行声明,否则会抛出 ReferenceError。在非严格模式下,未声明的变量会被隐式创建,并被添加到全局对象(比如浏览器环境中的 window 对象)中。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">2. 禁止删除变量、函数或函数参数:在严格模式下,使用 delete 操作符删除变量、函数或函数参数会抛出 SyntaxError。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">3. 禁止对只读属性进行赋值:在严格模式下,对只读属性(通过 const 关键字声明的常量)进行赋值会抛出 TypeError。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">4. 禁止使用八进制字面量:在严格模式下,以 0 开头的数字会被视为八进制字面量,这在非严格模式下是允许的。严格模式下,使用八进制字面量会抛出 SyntaxError。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">5. 限制 this 值:在严格模式下,函数内部的 this 值不再是全局对象(比如浏览器环境中的 window 对象),而是undefined,除非通过 call()、apply() 或 bind() 明确指定。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">6. 禁止使用重复的函数参数名:在严格模式下,函数参数名不能重复。在非严格模式下,重复的函数参数名会被忽略。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">7. 禁止使用 with 语句:在严格模式下,使用 with 语句会抛出 SyntaxError。with 语句在非严格模式下允许将对象的属性添加到作用域链中,但这被认为是不推荐使用的特性,因为它可能导致代码可读性和性能问题。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">8. 限制 eval 和 arguments 的赋值:在严格模式下,无法对 eval 和 arguments 进行赋值。在非严格模式下,这种赋值是允许的。</span></p><p style="text-align: justify;"><br></p><p style="text-align: justify;"><span style="font-size: 15px;">下面是一些使用JavaScript严格模式的例子,展示了严格模式下的限制和行为变化:</span></p><p style="text-align: justify;"><span style="font-size: 15px;">1. 变量必须先声明后使用:</span></p><pre><code class="language-javascript">"use strict"; x = 10; // 抛出 ReferenceError: x is not defined</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,对未声明的变量进行赋值会抛出错误。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">2. 禁止删除变量:</span></p><pre><code class="language-javascript">"use strict"; var x = 10; delete x; // 抛出 SyntaxError: Delete of an unqualified identifier in strict mode.</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,无法使用 delete 操作符删除变量。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">3. 禁止对只读属性进行赋值:</span></p><pre><code class="language-javascript">"use strict"; var obj = {}; Object.defineProperty(obj, "x", { value: 10, writable: false }); obj.x = 20; // 抛出 TypeError: Cannot assign to read only property 'x' of object ' <Object>'</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,对只读属性进行赋值会抛出错误。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">4. 八进制字面量的限制:</span></p><pre><code class="language-javascript">"use strict"; var num = 012; // 抛出 SyntaxError: Octal literals are not allowed in strict mode.</code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,使用八进制字面量会被视为语法错误。</span></p><p style="text-align: justify;"><span style="font-size: 15px;">5. 函数中的 this 值为 undefined:</span></p><pre><code class="language-javascript">"use strict"; function showThis() { console.log(this); } showThis(); // undefined </code></pre><p style="text-align: justify;"><span style="font-size: 15px;">在严格模式下,如果函数内部的 this 值未明确指定,它将保持为 undefined。</span><br><span style="font-size: 15px;">这些是严格模式下的一些限制和变化,它们有助于提高代码的可靠性和可维护性。在编写新代码或更新现有代码时,启用严格模式是一种良好的实践,可以帮助捕获潜在的错误并遵循更严格的编码标准。</span></p><p><br></p>
评论 (
0
)
登录
后才可以发表评论
状态
待办的
待办的
进行中
已完成
已关闭
负责人
未设置
标签
Html/JS/CSS
未设置
标签管理
里程碑
未关联里程碑
未关联里程碑
Pull Requests
未关联
未关联
关联的 Pull Requests 被合并后可能会关闭此 issue
分支
未关联
未关联
master
开始日期   -   截止日期
-
置顶选项
不置顶
置顶等级:高
置顶等级:中
置顶等级:低
优先级
不指定
严重
主要
次要
不重要
参与者(1)
1
https://gitee.com/DreamCoders/CoderGuide.git
git@gitee.com:DreamCoders/CoderGuide.git
DreamCoders
CoderGuide
CoderGuide
点此查找更多帮助
搜索帮助
Git 命令在线学习
如何在 Gitee 导入 GitHub 仓库
Git 仓库基础操作
企业版和社区版功能对比
SSH 公钥设置
如何处理代码冲突
仓库体积过大,如何减小?
如何找回被删除的仓库数据
Gitee 产品配额说明
GitHub仓库快速导入Gitee及同步更新
什么是 Release(发行版)
将 PHP 项目自动发布到 packagist.org
评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册