JavaScript中使用“严格”是什么,它背后的推理是什么?

在JavaScript中,“严格模式”是一种可选特性,它允许开发人员编写更加安全、规范的代码。本文将详细介绍JavaScript的严格模式及其背后的推理,以及如何正确地使用它来提高代码质量。

什么是严格模式?

简单来说,严格模式就是一种JavaScript变体,它使得JavaScript引擎执行更加严格的语法解析和错误处理。在严格模式下,一些不规范的行为被禁止,并且会抛出异常或者产生错误。

开启严格模式的方式很简单,只需要在JavaScript文件或函数的顶部添加"use strict";即可。例如:

---- --------
-------- ------------ -
  -- ---------------
  --- - - ---
  ------ --
-

严格模式的推理

防止意外创建全局变量

在非严格模式下,如果我们忘记使用varlet关键字定义一个变量,则该变量将被自动创建为全局变量。这样做有时可能会导致意想不到的后果,尤其是在多人协作的项目中。

在严格模式下,如果我们忘记定义变量,则会抛出一个ReferenceError错误。这可以帮助我们及时发现潜在的问题。

-- -----------------
-------- ------------ -
  - - ---
-

-------------
--------------- -- ----

-- --------------------------------
---- --------
-------- ------------ -
  - - ---
-

------------- -- ------------------

消除Javascript语法限制

在非严格模式下,JavaScript有一些奇怪的语言行为和约定,例如在函数内部使用this关键字可能是非常难以预测的。严格模式消除了这些非常规的行为,并强制执行更加一致的JavaScript语法。

-- -------------------
-------- ------------ -
  ------------------
-

------------- -- ------

-- -----------------------
---- --------
-------- ------------ -
  ------------------
-

------------- -- -----------

禁止重复的属性名或参数名

在非严格模式下,我们可以在对象中定义多个相同名称的属性或函数中定义多个相同的参数名,这可能导致代码出现意外的行为。

在严格模式下,重复属性名或参数名将会抛出一个SyntaxError错误。这可以帮助我们避免这种不规范的行为。

-- --------------------
----- ----- - -
  -- --
  -- -- -- ----
--

-- --------------------
-------- ------------- -- -
  ------ - - -- -- ---
-

------------- ---

-- -------------------------------
---- --------
----- ----- - -
  -- --
  -- -- -- ---------------
--

---- --------
-------- ------------- -- - 
  ------ - - -- -- ---------------
-

------------- ---
--

---------------------------------------------------------- ----------
-------------------------------------------------------------------------------------
  

猜你喜欢

  • hls.js 源码解读【2】

    在前一篇文章中,我们简单介绍了 HLS 协议和 hls.js 的基本原理。在本文中,我们将深入探讨 hls.js 的源代码,重点关注 hls.js 的实现细节和技术细节。

    7 年前
  • Ember.js 3.0 发布 | 无新功能,淘汰过时 API,优化 CLI 工具

    Ember.js 3.0 发布:淘汰过时 API,优化 CLI 工具 Ember.js 是一款开源的 JavaScript 前端框架,其目标是帮助开发者构建高度交互且可维护的 Web 应用程序。

    7 年前
  • [Podcast] [] The Future of RxJS 6 & 7 - Roadmapping Operators

    [Podcast] The Future of RxJS 6 & 7 - Roadmapping Operators Introduction RxJS is a popular librar...

    7 年前
  • Master the JavaScript Interview: What is a Promise?

    If you've been working with JavaScript for any length of time, you've likely encountered Promises. B...

    7 年前
  • javascript可选的链式调用可能到来了

    JavaScript可选的链式调用可能到来了 JavaScript是一种动态类型、面向对象的编程语言,广泛应用于Web前端开发中。随着ES6(ECMAScript 2015)规范的发布,JavaScr...

    7 年前
  • Weex: Review and Comparison with React Native

    Weex and React Native are two popular cross-platform frameworks for building mobile applications. Th...

    7 年前
  • 对运行时转的一次尝试

    运行时转译的一次尝试 随着前端技术的不断发展,越来越多的新特性被引入到 JavaScript 中。但是这些新特性并不是所有浏览器都支持的,这就导致了在开发过程中需要考虑兼容性问题。

    7 年前
  • 关于移动端开发中遇到的坑

    在移动端开发中,由于不同设备、浏览器的差异性以及用户体验的要求,经常会遇到各种问题和坑点。本文将介绍一些常见的移动端开发坑点,并提供解决方案和指导意义。 1. Retina屏幕下的图像模糊问题 Ret...

    7 年前
  • 使用 SVG 打造一个高质量的 ICON 系统

    使用 SVG 打造高质量 ICON 系统 介绍 ICON 是任何 Web 应用程序的重要组成部分。它们可以帮助用户轻松找到所需功能,增强品牌认知度,并使应用程序更加美观。

    7 年前
  • 基于对象的事件绑定

    在前端开发中,事件绑定是非常重要的一个概念。它使得我们可以在用户与页面进行交互时触发相应的动作,从而实现丰富的用户体验。本文将介绍基于对象的事件绑定,包括其原理、使用方法以及注意事项。

    7 年前
  • [官方][Safari Webkit - 支持新的 Storage Access API

    Safari WebKit - 支持新的 Storage Access API Safari WebKit 是苹果公司开发的 Web 渲染引擎,在最近的版本中增加了对新的 Storage Access...

    7 年前
  • Blotter.js - 快速实现各种字体动画效果

    Blotter.js 是一款用于创建高质量、炫酷的字体动画效果的 JavaScript 库。Blotter.js 提供了多种渲染效果和样式,可以轻松实现惊人的视觉效果,轻松实现各种创新性的设计。

    7 年前
  • 渐进式图片以及用户体验方面的影响

    在前端开发中,图像是网站和应用程序中不可或缺的一部分,但它们也可以对性能和用户体验产生负面影响。其中一个解决方案是使用渐进式图像。 什么是渐进式图像? 渐进式图像是指在加载过程中逐步显示的图像。

    7 年前
  • 随机方法总结

    前端随机方法总结 在前端开发中,经常需要使用到随机数方法,比如生成随机密码、随机颜色等。本文将介绍一些常用的前端随机方法,并探讨它们的实现方式、使用场景以及注意事项。

    7 年前
  • js正则字符串

    JavaScript 正则表达式与字符串操作 正则表达式是一种强大的工具,它能够帮助开发者处理和操作字符串。JavaScript 的正则表达式内置于语言中,因此可以方便地使用。

    7 年前
  • 一次记住js的6个正则方法

    一次记住JS的6个正则方法 在前端开发中,正则表达式是一个非常重要的工具。它可以用于验证用户输入、搜索和替换字符串等各种场景。本文将介绍JS中常用的6个正则方法,希望能够帮助你更好地掌握这个强大的工具...

    7 年前
  • 前端面试题目大全

    前端面试题目大全 前端开发是一个快速变化的领域,需要不断学习和掌握新技术。在面试中,经常会被问及各种前端知识。以下是一些常见的前端面试题目,包括深度和指导意义。 HTML 部分 1. 请解释一下 HT...

    7 年前
  • Java与Javascript的区别、联系及其问题

    Java和Javascript是两种不同的编程语言,尽管它们有些相似之处,但也有很多的差异。在前端开发中,对于这两种语言的理解和应用都非常重要,以下将详细介绍它们的区别、联系以及常见问题。

    7 年前
  • react-native 超方便好用toast组件支持ios、android

    React-Native 轻松实现跨平台 Toast 组件 在移动端开发中,Toast 作为一种轻量级的提示组件,在用户体验中扮演着非常重要的角色。而在 React-Native 技术栈中,我们可以使...

    7 年前
  • FE-Interview-questions(前端面试题/知识点)

    的title和alt有什么区别](#img%E7%9A%84title%E5%92%8Calt%E6%9C%89%E4%BB%80%E4%B9%88%E5%8C%BA%E5%88%AB) ...

    7 年前

相关推荐

    暂无文章