本文主要是介绍关于 JavaScript 语句后是否应该加分号,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
可能是受c++,c#风格影响比较深,一半出于强迫症,之前一直是个分号党。
最近看各种大神和教程的代码都并不写分号。调研了一下,从此拥抱前置分号。
==================================================================
以下摘自 @贺师俊 在某乎的回答:
总结下“分号党”推崇的“总是写分号”风格的最主要缺陷:
1. 人总是有可能忘记写分号。ASI(分号自动插入机制)导致无法区分是无意中忘记还是有意不写(代码折行)。
2. “总是写分号”并不能完全解决ASI缺陷(如return后换行会自动插入分号)。
3. “}”后是否要加分号需要回溯到对应“{”之前进行语义判断(是否是函数表达式),成本远高于前置分号判断(只要对行首字符进行token判断:是否是 [ ( + - / 五个符号之一)。
如:
a = b
(function(){
...
})()
会被解释为 a = b(function(){...})()
其实如果我们真想表达上述代码,通常会这样写:
a = b(function(){
...
})()
再如:
a = b
[1,2,3].forEach(function(e){
console.log(e)
})
实际效果等价于
a = b[3].forEach(function(e){
console.log(e)
})
坑爹的是,搞不好这代码说不定还能运行!你要事后通过调试发现这些错误是相当滴痛苦啊。
不过这些问题的解决方案其实也很简单。只要在 [ 、 ( 、 + 、 -、/ 之前加分号就可以了:
a = b
;(function(){
...
})()
a = b
;[1,2,3].forEach(function(e){
console.log(e)
})
这篇关于关于 JavaScript 语句后是否应该加分号的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!