iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript中分号的一些细节
  • 806
分享到

JavaScript中分号的一些细节

2024-04-02 19:04:59 806人浏览 独家记忆
摘要

前言 javascript 中的分号是可选的,加不加分号主要是个代码风格问题。一种风格是使用分号明确结束语句,即便这些分号不是必需的;另一种风格是尽可能的不加分号,只在必要的情况才

前言

javascript 中的分号是可选的,加不加分号主要是个代码风格问题。一种风格是使用分号明确结束语句,即便这些分号不是必需的;另一种风格是尽可能的不加分号,只在必要的情况才加。我个人就不喜欢加分号,当然喜欢加分号的朋友也不少。无论你喜欢哪种风格,都需要了解了解 JavaScript 中的分号的一些细节。

代码中分号的作用

分号的主要作用是:作为语句的断言(EOS)用于结束一个程序语句,目的是让解析器正确解析程序。在很多 C-Style 语言里,用分号明确结束一行语句,主要是为了降低语言编译器开发的成本。但是现代编译器都足够聪明了,可以很好的处理好多行语句。很多语言都不需要明确使用分号结尾如:GoScala、Ruby、python、Swift、Groovy 等等。

虽然 JavaScript 是 C-like 语言,但它是有别于 C、Java 的,在 JavaScript 中分号也是可选的,它自动分号插入机制 Auto Semicolon Insertion (ASI)。

JavaScript 自动分号插入机制

JavaScript 有着自动分号插入的机制(Automatic Semicolon Insertion),简称 ASI。在ECMA-262 - Automatic Semicolon Insertion中有关 Automatic Semicolon Insertion 的明确说明:

从左到右解析程序,当遇到一个不符合任何文法产生式的 token(offending token),那么只要满足下面条件之一就在违规 token 前面自动插入分号。

  • 至少一个换行符(LineTerminator)分割了违规 token 和前一个 token。
  • 违规 token 是 }。

从左到右解析程序,tokens 输入流已经结束,当解析器无法将输入 token 流解析成单个完整 ECMAScript 程序 ,那么就在输入流的结束位置自动插入分号。

从左到右解析程序,遇到一个某些文法产生式允许的 token,但是它是受限操作(Restricted Productions),当至少一个换行符分割了受限的 token 和前一个 token,那么就在受限 token 前面自动插入分号。

然而,上述规则有一个附加的优先条件:如果插入分号后解析结果是空语句,或如果插入分号后它成为 for 语句头部的两个分号之一,那么不会自动插入分号。

注:以上说明翻译较为别扭可以多读几遍或阅读英文原文 ECMA-262 - Automatic Semicolon Insertion

分号自动插入的情况

简要归纳下,自动分号插入以换行为基础,解析器会尽量将新行并入当前行,当且仅当符合 ASI 规则时才会将新行视为独立的语句

主要有以下自动插入规则:

  1. 当新的一行并入当前行将构成非法语句不能正确解析时,将自动插入分号
  2. 当新行以}开头时,即代码块的结束位置,将自动插入分号
  3. 当以return语句结束时, 在行末自动插入分号
  4. 当以break语句结束时, 在行末自动插入分号
  5. 当以throw语句结束时,在行末自动插入分号
  6. 当以continue语句结束时, 在行末自动插入分号
  7. 当以 es6 的 yield 语句结尾时,在行末自动插入分号
  8. ++、-- 后缀表达式作为新行的开始,在行首自动插入分号
  9. 源代码文件末尾自动插入号

如上所示,如果没加分号,运行这段代码这段代码将报错。

不能省略分号的情况

通常,如果语句以(、[、 /、+、-开头时,就有可能被解释为上一行语句的一部分。实际中以/、+、-开头的语句很少。但是以(、[开头的语句则很常见,通常我可以在行首防御性的加上分号。

前面,我们了解分号的自动插入,现在我们来看一些示例


let hey = 'hey'
['liu','liuxing'].forEach(console.log)

思考一秒种上面的结果是什么?运行这段代码会抛出


Uncaught TypeError: Cannot read property 'forEach' of undefined

基于规则 1 上面代码将会被解析成如下代码


let hey = 'hey'['liu','liuxing'].forEach(console.log)

可以看出,使用[开头的语句,前面没有分号,很可能导致出错。

再来看一个(开头的语句的示例代码


const a = 1
const b = 2
const c = a + b
(a + b).toString()

你会以为上面的代码结果是“3”吗?但是实际上它会抛出错误b is not a function,因为根据 ASI 规则,它会被解析成如下代码:


const a = 1;const b = 2;const c = a + b(a + b).toString()

我们就不一一介绍/, +, - 作为语句开头的情况了,这种情况比较少,大家可以自己试试。只需要记住语句以(、[、 /、+、-开头时,语句前需要加上分号即可!

下面再在看看使用return的情况,


(() => {
  return
  {
    name: 'Liu Xing'
  }
})()

你的期待值是不是返回一个带有 name 的对象,但是它却返回了undefined。这是 ASI 自动在return给加上了分号。在这儿就得正确的换行以确保代码正确运行。我们可以看出除了正确的的分号,我们还需要正确合理的换行来使代码结构更为清晰。

总结

我们了解了 JavaScript 的分号自动插入机制,知道了 JavaScript 什么时候会自动加入分号,在(、[、 /、+、-开头时需要我们准确的加上分号。Automatic Semicolon Insertion 机制为我们提供了两种选择,加还是加分号?完全看你或你的团队的喜好了,现在我们也有prettier、Eslint 等工具来自动统一风格。

到此这篇关于JavaScript中分号的文章就介绍到这了,更多相关JavaScript分号内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript中分号的一些细节

本文链接: https://www.lsjlt.com/news/125187.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中分号的一些细节
    前言 JavaScript 中的分号是可选的,加不加分号主要是个代码风格问题。一种风格是使用分号明确结束语句,即便这些分号不是必需的;另一种风格是尽可能的不加分号,只在必要的情况才...
    99+
    2024-04-02
  • Javascript中需要注意的细节有哪些
    这篇文章主要介绍了Javascript中需要注意的细节有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.使用 === 代替 ==Jav...
    99+
    2024-04-02
  • Java中那些分不清的小细节有哪些
    本篇内容主要讲解“Java中那些分不清的小细节有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中那些分不清的小细节有哪些”吧! 前言最近我们通过sonar静态代码检测,同时...
    99+
    2023-06-15
  • C++实现二分法的一些细节(常用场景)
    二分法是在一个排好序的序列(数组,链表等)中,不断收缩区间来进行目标值查找的一种算法,下面我们就来探究二分法使用的一些细节,以及常用的场景: 寻找一个数;寻找左侧边界;寻找右侧边界。...
    99+
    2024-04-02
  • JavaScript中DOM节点的详细介绍
    本篇内容主要讲解“JavaScript中DOM节点的详细介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中DOM节点的详细介绍”吧!使用H...
    99+
    2024-04-02
  • javascript中分号和逗号的区别有哪些
    这篇“javascript中分号和逗号的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看...
    99+
    2024-04-02
  • 容易被忽视的JavaScript细节有哪些
    今天就跟大家聊聊有关容易被忽视的JavaScript细节有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。语句/表达式换个角度理解语句(state...
    99+
    2024-04-02
  • Java前后端交互的一些细节
     在后端进行POST请求后端接收前端数据时,关于PrintWriter:参考地址 注意传进来的对象为空说明未在数据库查到拥有该账号的用户,所以需要告诉前端“账号密码不正确”,如果不为空说明有该用户,所以可以登录。  @Overrid...
    99+
    2023-10-12
    java 交互 servlet 开发语言
  • Linux Shell的信号trap功能细节有哪些
    这篇文章给大家介绍Linux Shell的信号trap功能细节有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。它有三种形式分别对应三种不同的信号回应方式.第一种: trap 'commands' s...
    99+
    2023-06-06
  • C语言中的细节分析
    这篇文章主要介绍了C语言中的细节分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。计算型细节①:#include <stdio.h>int m...
    99+
    2023-06-15
  • Javascript数据类型中有哪些可能会中招的细节
    今天就跟大家聊聊有关Javascript数据类型中有哪些可能会中招的细节,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 前言Javascr...
    99+
    2024-04-02
  • javascript ES6中箭头函数注意细节有哪些
    小编给大家分享一下javascript ES6中箭头函数注意细节有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言ES6标...
    99+
    2024-04-02
  • 细说JS数组遍历的一些细节及实现
    目录1. 数组空位问题 ​1.1 空位判断 ​1.2 刚列举了数组的一些操作会对空位进行跳过,但其实,它们在处理上也还是存在一些差异的2. 是否修改原数组 ​3. 附一下数组遍历的几...
    99+
    2023-05-20
    JS数组遍历
  • SEO中容易被忽视的细节分析有哪些
    这篇文章主要为大家展示了“SEO中容易被忽视的细节分析有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SEO中容易被忽视的细节分析有哪些”这篇文章吧。第一,标签的应用,建设比较早的站容易出现...
    99+
    2023-06-13
  • JavaScript中节流的示例分析
    小编给大家分享一下JavaScript中节流的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言我们来聊一聊节流——另一个优化函数的思想。我们还是以移动事...
    99+
    2023-06-06
  • C#中数组的细节有哪些
    这篇文章主要讲解了“C#中数组的细节有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C#中数组的细节有哪些”吧!C# 数组细节在 C# 中,数组是非常重要的,且需要了解更多的细节。下面列...
    99+
    2023-06-17
  • JavaScript初学者应注意的细节有哪些呢
    本篇文章给大家分享的是有关JavaScript初学者应注意的细节有哪些呢,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。每种语言都有它特别的地方...
    99+
    2024-04-02
  • Python初学者容易忽略的一些细节
    1、Python中当让给变量1赋值上变量2的值时,变量1直接指向值在内存中存储的地址,即变量1存储的是变量2的值而不是指向变量   2、"""的用法 1.多行注释 2.多行输出 3、格式化输出的三种方法 1.字符串拼接(占用内存大慎...
    99+
    2023-01-31
    初学者 细节 Python
  • 全面分析MySQL的细节
    本篇内容主要讲解“全面分析MySQL的细节”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“全面分析MySQL的细节”吧!一、EXPLAIN做MySQL优化,我们要...
    99+
    2024-04-02
  • Python的py文件中有哪些细节
    本篇内容介绍了“Python的py文件中有哪些细节”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!模块是一种以.py为后缀的文件,我们可以在....
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作