您的位置是:网站首页>Javascript编程Javascript编程

介绍 JavaScript 代码加不加分号有什么区别

少儿编程网2021-05-25 16:24:26Javascript编程 人已围观 来源:少儿编程 -用户投稿

简介javascript栏目介绍代码加不加分号的区别是什么推荐(免费):javascript(视频)这个问题在很多文章中都讨论过,在ESlint规范中也因为加不加分号而分为两大阵营,到于加不加分号,关键是需要了解分号对于JavaScript的影响,开始之前可以先看看下面这道面试题:请问这段代码是否能够正

javascript栏目介绍代码加不加分号的区别是什么0Ll少儿编程网-https://www.pxcodes.com

0Ll少儿编程网-https://www.pxcodes.com

推荐(免费):javascript(视频)0Ll少儿编程网-https://www.pxcodes.com

这个问题在很多文章中都讨论过,在 ESlint 规范中也因为加不加分号而分为两大阵营,到于加不加分号,关键是需要了解分号对于 JavaScript 的影响,开始之前可以先看看下面这道面试题:0Ll少儿编程网-https://www.pxcodes.com

请问这段代码是否能够正常运行?0Ll少儿编程网-https://www.pxcodes.com

var a = 1
(function() {
  console.log(2)
})()

0Ll少儿编程网-https://www.pxcodes.com

0Ll少儿编程网-https://www.pxcodes.com

0Ll少儿编程网-https://www.pxcodes.com

0Ll少儿编程网-https://www.pxcodes.com

如果运行这段代码,会出现下面的错误:0Ll少儿编程网-https://www.pxcodes.com

Uncaught TypeError: 1 is not a function

什么鬼!1 is not a function ?我们没有打算运行数字 1,为什么说数字 1 不是函数,这种错误是很难找到原因的,经常会在出问题的代码行上打转。这个错误必然是上吗的代码在运行时被看作是同一行,其概念如下:0Ll少儿编程网-https://www.pxcodes.com

var a = 1(function() { /* */ })()

因此立即函数的 () 被附加在 1 上,这是一个调用函数的语法,所以会产生 1 is not a function 的错误,想要避免这个错误就需要使用分号:0Ll少儿编程网-https://www.pxcodes.com

var a = 1 // 随便把分号放在哪里,只要能隔开就行
;(function() {
  console.log(2)
})()

ASI 自动加入分号0Ll少儿编程网-https://www.pxcodes.com

ASI是 “Automatic Semicolon Insertion” 的缩写,在运行时会往有些折行的代码中自动插入分号,这个机制可以使部分代码在没有加入分号时也能正常运行,比如下面的例子:0Ll少儿编程网-https://www.pxcodes.com

var b = 1
++b
console.log('b', b)

由于代码中的 ++ 属于一元表达式,它只能在表达式的左边右边放置变量,如果没有 ASI 的机制,代码会被转换为 var b = 1 ++ b 这样的错误语句。不过好在有 ASI,在实际运行时会自动被加入分号,也就不会出现上面的错误。0Ll少儿编程网-https://www.pxcodes.com

var b = 1;
++b;
console.log('b', b); // 2

return 与分号的关系0Ll少儿编程网-https://www.pxcodes.com

再来看一个例子,下面的代码在 return 的后面空一行后再写要返回的值,那么问运行结果是什么呢?0Ll少儿编程网-https://www.pxcodes.com

function fn() {
  return 
  '小明'
}
console.log(fn())

这段程序代码因为 ASI 的修正,return 的后面会被加上一个分号,所以 return 与预期返回的值被分开了,结果 return 的内容为空值,**终的结果也只能是 undefined0Ll少儿编程网-https://www.pxcodes.com

function fn() {
  return;
  '小明';
}
console.log(fn()); // undefined

到底应该怎样处理分号0Ll少儿编程网-https://www.pxcodes.com

本来 ASI 是出于一片好心,用来修正没有加入分号的代码片段,但偏偏在有的地方并没有发挥它的作用(例如本文一开始所介绍的立即函数),导致代码出现了错误;甚至有些代码不会出错,但会使你的代码执行结果和预期相差万里。0Ll少儿编程网-https://www.pxcodes.com

解决 ASI 问题的方式如下:0Ll少儿编程网-https://www.pxcodes.com

  • 无论如何都要加上分号,完全由自己决定代码的分割
  • 牢记不会自动加入分号的规则,当不会自动插入分号时,则手动加入

不会被自动加入分号的规则0Ll少儿编程网-https://www.pxcodes.com

下面时各种不会自动加入分号的规则:0Ll少儿编程网-https://www.pxcodes.com

  1. 新行的代码是从 ([/ 字符开始的,这类情况一般会直接出现 Uncaught TypeError 从而导致代码无法运行。
var a = 1
var b = a
(a + b).toString()

var a = 1
[1,2,3].forEach(bar)
 
(function() { })()
(function() { })()
 
var a = 1
var b = a
/test/.test(b)
  1. 新行以 +-* 开始,这类情况大多会影响运算结果,所以应该合并为一行。
var a = 2
var b = a
+a
  1. 新行以 ,. 开始,这种用法经常会出现,主要是为了避免代码过长而加入的分隔,这种情况并不会影响运行,如果善用的话会使代码更容易阅读。
var a = 2
var b = a
  .toString()
console.log(typeof b)
 
var a = 1
,b = 2 // b 同样会被 var 声明

如果遇到需要加入分号的情况,除了可以在语句的末尾加入分号外,也可以把分号加在“不会自动加入分号”的**前方,例如 () 本身不会自动加入分号,在有这种需求时可以将 ; 加到前面(ESLint Standard JS 规范就用这个方法避免错误)。0Ll少儿编程网-https://www.pxcodes.com

// 运行错误
(function() { })()
(function() { })()
 
// 正确
;(function() { })()
;(function() { })()

总结0Ll少儿编程网-https://www.pxcodes.com

有的人认为不加分号可以让代码看起来更干净和精简,而且在大部分情况下并不会出现错误,所以很多人在敲代码时不会加分号。0Ll少儿编程网-https://www.pxcodes.com

不过我更倾向于更严格的规范,也许是因为我是从后端转到前端的,习惯了。至于到底怎么选,只要搞清楚运行上的限制,不管哪种风格都是挺不错的,只要你喜欢就好。

以上就是介绍 JavaScript 代码加不加分号有什么区别的详细内容,更多请关注少儿编程网其它相关文章!0Ll少儿编程网-https://www.pxcodes.com

来源:php中文网0Ll少儿编程网-https://www.pxcodes.com


相关文章:

支持一下 ( )

介绍 JavaScript 代码加不加分号有什么区别

      匿名评论
    • 评论
    人参与,条评论
    介绍 JavaScript 代码加不加分号有什么区别

微信公众号

免费视频教程

先知道