javascript要不要加分号

JavaScript中的分号是可选的,加不加分号主要是个代码风格问题,但是不要一会加一会不加。通常,如果语句以“(”、“[”、“/”、“+”、“-”开头时,有可能被解释为上一行语句的一部分;此时可以在行首防御性的加上分号。

javascript要不要加分号

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

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

1.png

注:分号可以加也可以不加,但是不要一会加一会不加。

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

代码中分号的作用

分号的主要作用是:作为语句的断言(EOS)用于结束一个程序语句,目的是让解析器正确解析程序。在很多 C-Style 语言里,用分号明确结束一行语句,主要是为了降低语言编译器开发的成本。但是现代编译器都足够聪明了,可以很好的处理好多行语句。很多语言都不需要明确使用分号结尾如:Go、Scala、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 规则时才会将新行视为独立的语句

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

当新的一行并入当前行将构成非法语句不能正确解析时,将自动插入分号

当新行以}开头时,即代码块的结束位置,将自动插入分号

当以return语句结束时,在行末自动插入分号

当以break语句结束时,在行末自动插入分号

当以throw语句结束时,在行末自动插入分号

当以continue语句结束时,在行末自动插入分号

当以 ES6 的 yield 语句结尾时,在行末自动插入分号

++、– 后缀表达式作为新行的开始,在行首自动插入分号

源代码文件末尾自动插入号

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

不能省略分号的情况

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

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

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 = 1const b = 2const 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要不要加分号的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2925545.html

(0)
上一篇 2025年3月11日 19:07:45
下一篇 2025年3月3日 19:12:54

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JavaScript可以单独运行吗

    JavaScript不可以单独运行。JavaScript是一种脚本语言,不能像exe程序一样单独运行,只能在宿主环境中执行。两种运行方法:1、使用script标签把JavaScript代码放在HTML中,借助浏览器环境来运行;2、借助nod…

    2025年3月11日 编程技术
    200
  • javascript为什么用函数式编程

    原因:1、js的语法是从Scheme这种函数式编程语言借鉴而来。2、就浏览器端而言,随着各种单页框架的发展,客户端的处理能力不断提升,越来越多的业务逻辑被放到端,从而导致客户端要维护的状态越来越多;随之而来的问题是,一不小心就会大量使用依赖…

    2025年3月11日
    200
  • javascript中有几种类型

    有9种数据类型:1、字符串类型,是一段以引号包裹起来的文本;2、数值类型,用来定义数值;3、布尔类型,只有两个值;4、Null类型,表示一个“空”值,即不存在任何值;5、Undefined类型,表示未定义;6、Symbol类型,表示独一无二…

    2025年3月11日
    200
  • javascript数组怎么求平均数

    两种求平均数的方法:1、利用forEach()和length属性来求,语法“function f(v){s+=v;}数组对象.forEach(f);avg=s/数组对象.length;”;2、利用reduce()和length属性来求,语法…

    2025年3月11日
    200
  • javascript支持不定长参数吗

    javascript支持不定长参数。实现不定长参数的两种方法:1、利用arguments对象,arguments对象的长度是由实参个数而不是形参个数决定的;对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况…

    2025年3月11日 编程技术
    200
  • javascript中double的意思是什么

    double的意思是“双精度浮点数”,使用64位(8字节) 来存储一个浮点数,它是JavaScript的一种保留字。double(双精度浮点数)可以表示十进制的15或16位有效数字,其可以表示的数字的绝对值范围大约是“-1.79E+308”…

    2025年3月11日
    200
  • JavaScript只能写前端吗

    JavaScript不是只能写前端,它也可写后端;JavaScript可以利用Node.js来实现后端开发。Node.js是一个让JavaScript运行在服务端的开发平台,是一个事件驱动“I/O”服务端JavaScript环境,可以将No…

    2025年3月11日
    200
  • JavaScript怎么求两个数的商

    两种实现方法:1、使用算术运算符“/”,语法“操作数1 / 操作数2”,可以将运算符两侧的操作数相除并返回商;2、使用赋值运算符“/=”,会先进行除法运算,再将结果赋值给运算符左侧的变量,语法“x /= y”,等同于“x = x / y”。…

    2025年3月11日 编程技术
    200
  • javascript怎么求次方和

    求次方和的步骤:1、利用Math对象的pow()函数来分别求出指定数的N次方,语法“Math.pow(指定数, N)”,会返回指定数的次方值;2、使用“+”运算符将获取的多个次方值相加求和即可,语法“次方值1 + 次方值2 + 次方值3&#…

    2025年3月11日 编程技术
    200
  • javascript怎么求偶数的和

    求偶数和的步骤:1、将多个数存入数组中,语法“var 数组变量名 =[数值1,数值2,数值3…];”;2、定义一个变量并赋值为0,用于存储求和结果,语法“var sum=0;”;3、使用for语句遍历数组找出偶数值,并利用“+=…

    2025年3月11日 编程技术
    200

发表回复

登录后才能评论