JavaScript到底应不应该加分号?JavaScript自动插入分号规则详解

这篇具有很好参考价值的文章主要介绍了JavaScript到底应不应该加分号?JavaScript自动插入分号规则详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

JavaScript 提供了 automatic semicolon insertion (ASI)自动插入分号规则,在不加分号的情况下,会自动补充分号来分隔不同语句。

导致在继左大括号换行、tab 和 space 圣战后,前端又出现了一场战争。

并且随着那个男人加入这场讨论之后,关于是否应该加分号的讨论更是激烈了。

JavaScript到底应不应该加分号?JavaScript自动插入分号规则详解

ASI 自动插入分号规则

在决定是否添加分号之前,我们先来了解一下编译器到底在哪些情况下会自动插入分号,哪些情况必须手动添加分号。

会自动添加分号的情况

1.遇到换行符,但是两句代码连接是无效代码

// 代码
42
'hello'

// `42 'hello'`连接在一起是无效语句,所以会自动在之间插入分号
42;'hello'

// 直接明确的写法
42;"hello"
// 代码
let a = 10, b = 5
a
-
b

// a - b 为有效代码,所以三者之间不会自动加分号
a = 1; b = 2;

// 直接明确的写法
a - b

2.遇到换行符,但是两句代码之间不允许有换行符

// 代码
foo
++
bar
++
baz

// foo 和 ++ 符合规则1,但是不符合 no LineTerminator here规则,所以会添加分号
foo; 
++bar; 
++baz;

在 JS 标准中,有个 no LineTerminator here 的规则,规定哪些语法不能加入换行符,如果开发者加了换行符,则 JS 编译器会无法识别并加入分号。

  1. 带标签的continue语句,不能continue后插入换行;
  2. 带标签的break语句,不能在break后面插入换行;
  3. return后面不能插入换行;
  4. 后自增、后自减运算符前不能插入换行;
  5. throwException之间不能插入换行;
  6. async关键字,后面不能插入换行;
  7. 箭头函数的箭头前,不能插入换行;
  8. yield之后,不能插入换行。

3.Restricted productions
如果这些标签后,空一行书写其它语句,则会自动在这些标签后添加分号:

  • ++ or --
  • return
  • break
  • continue
  • ES6 yieldasync
  • 反引号`
// return 后空一行再书写语句,则会自动在 return 后加分号
return
{
  a: 1
}

// 这是正确写法
return {
  a: 1
}

其它标签类似。

如果手动在这些标签后加上分号,同样也是错误的,比如:

// 空一行再写 a,会自动在 ++ 后添加分号
++
a

// 就算手动添加,和上面结果一样是错误的
++;
a;

所以针对 Restricted productions ,无论让编译器自动添加分号,还是自己手动加上分号,都是错误的,都应该去避免去换行,避免写这种写法。

必须手动加分号的情况

以下面这些标签开头的命令,必须在前面加分号,和前面一个语句分隔:

  • +-:语句以 + 或者 - 开头
  • /: 语句以正则表达式开头
  • ( : 语句以自执行函数开头
  • [: 语句以数组开头

举例说明:

// 错误
a = b
+a
// 正确
a = b
;+a


// 错误
a = b
/something/.test(a)
// 正确
a = b
;/something/.test(a)

// 错误
a = b
(function () {})()
// 正确
a = b
;(function() {})()

// 错误
a = b
[1, 2, 3].forEach()
// 正确
a = b
;[1, 2, 3].forEach()

上面的情况,如果第二行代码不手动添加分号的话,两行代码会合并在一起导致结果错误或者报错。

上面几种情况中,只有自执行函数和数组开头会在极少情况下遇到,记住这两个前面要手动加上分号即可。

就算是习惯加分号的朋友,但仍然要注意下面的情况:

// 不需要结尾添加分号
if () {
} 

// 不需要结尾添加分号
for () {
} 

// 不需要结尾添加分号
while () {
} 

// 需要在结尾添加分号
var a = function () {
}; 

// 需要在结尾添加分号
var a = {
  prop: value
}; 

// 报错
[1, 2, 3].forEach();

即便习惯写分号的朋友,也很少有人在 ifforwhile 等语句 } 后写分号,但是如果使用赋值的形式传递,则一定要注意在 } 把分号添加上,以避免后面语句出现自执行和数组开头的语句。

推荐遇到自执行和数组开头的,直接前面加上分号就完事了。

总结

是否添加和是否手动加是两回事,我们可以用 eslint、Prettier 等工具自动生成或者删除分号,是否手动加可以看个人喜好,最终代码内可以根据项目要求用工具生成。

但都要注意必须添加分号的几种情况。文章来源地址https://www.toymoban.com/news/detail-801440.html

参考文章

  • Hacking Semicolons
  • What are the rules for JavaScript's automatic semicolon insertion (ASI)? - Stack Overflow

到了这里,关于JavaScript到底应不应该加分号?JavaScript自动插入分号规则详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【一文清晰】单元测试到底是什么?应该怎么做?

    我是java程序员出身,后来因为工作原因转到到了测试开发岗位。测试开发工作很多年后,现在是一名自由职业者 1、什么是单元测试 2、该怎么做单元测试 单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证。至于“单元”的大小或范围,并没有一个明确

    2024年02月07日
    浏览(35)
  • 哪个版本的FL Studio更适合我?2023年到底应该入手哪一款FL Studio?

    很多打算入手正版FL Studio的新手朋友都会纠结一个问题:哪个版本的FL Studio更适合我,2023年到底应该入手哪一款FL Studio?本文会介绍每个版本之间的差异点,并带大家选择适合自己的FL Sudio版本。 FL Studio Mac-安装包:https://souurl.cn/eW2mHz FL Studio Win-安装包:https://souurl.cn/0tjCE2

    2024年02月13日
    浏览(30)
  • 数字IC后端设计实现 | PR工具中到底应该如何控制density和congestion?(ICC2&Innovus)

    吾爱IC社区星友提问:请教星主和各位大佬,对于一个模块如果不加干预工具会让inst挤成一团,后面eco修时序就没有空间了。如果全都加instPadding会导致面积不够overlap,大家一般怎么处理这种问题? 在数字IC后端设计实现中经常会有这方面的困扰。这也是小编在咱们社区IC后

    2024年01月21日
    浏览(29)
  • JavaScript 的 for 循环应该如何学习?

    JS for 循环语法 JS for 循环适合在已知循环次数时使用,语法格式如下: for 循环中包含三个可选的表达式 initialization、condition 和 increment,其中: initialization: 为一个表达式或者变量声明,我们通常将该步骤称为“初始化计数器变量”,在循环过程中只会执行一次; condition:

    2024年02月07日
    浏览(38)
  • [Unity学习]使用ScrollRect实现自动滚动到底部显示实时消息,并在拖动的时候取消自动滚动,再次手动滑到底部,又继续自动滚动

    首先需要重写ScrollRect组件: 下面通过协程实现在不滚动ScrollRect的时候,自动滚动到底部。 使用时,写下面类似代码即可: Unity原生Scroll View更改配置如下: 其中ScrollView游戏物体更改组件如下: content配置如下: 实现效果如下: 大功告成!加上对象池模式控制添加的text实例

    2024年02月16日
    浏览(23)
  • 自动化测试到底是啥?

    什么是自动化测试?顾名思义就是以程序测试程序,自动执行指定动作,实现测试目的。以代码实现测试思维,以脚本替代手工执行。从简单的独立功能脚本到依托自动化框架运行的脚本集合都属于自动化测试范畴。本文旨在通过讨论以下几个方面,总结自动化测试价值最大化

    2024年02月12日
    浏览(35)
  • 从月薪3000到月薪20000,自动化测试应该这样学...

    绝大多数测试工程师都是从功能测试做起的,工作忙忙碌碌, 每天在各种业务需求学习和点点中度过,过了好多年发现自己还只是一个功能测试工程师。 随着移动互联网的发展,从业人员能力的整体进步,软件测试需要具备的能力要求越来越高,打开招聘网站 ,自动化测试

    2024年02月03日
    浏览(51)
  • 不应使用Excel进行项目资源规划的 7 个原因

    项目资源规划早期仅限于基本分配和调度。因此,企业使用自制工具或excel表来执行这一简单功能。然而,随着技术和业务流程的发展,资源规划变得复杂,并包括其他组成部分,如预测和容量规划,优化等。   由于传统的excel表无法处理这些复杂问题,企业开始采用专门的

    2023年04月20日
    浏览(18)
  • selenium 自动化测试:如何搭建自动化测试环境,搭建环境过程应该注意的问题

    最近也有很多人私下问我,selenium学习难吗,基础入门的学习内容很多是3以前的版本资料,对于有基础的人来说,3到4的差别虽然有,但是不足以影响自己,但是对于没有学过的人来说,通过资料再到自己写的代码,发现有些东西没有,有些方法又不相同,导致脚本不能运行

    2024年02月10日
    浏览(36)
  • js实现滚轮滑动到底部自动加载

    这里我们用vue实现(原生js相似), 这里我们用一个div当作一个容器; css样式 给上面div添加一个高度 在methods中编写我们的滚动条方法 onScroll(){        // let innerHeight=document.querySelector(\\\"JL\\\").clientHeight //js中使用         //let scrollHeight=document.querySelector(\\\"JL\\\").scrollHeight       

    2024年02月12日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包