最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
當前位置: 首頁 - 科技 - 知識百科 - 正文

關于JavaScript語句后面的分號問題

來源:懂視網 責編:小采 時間:2020-11-27 22:24:02
文檔

關于JavaScript語句后面的分號問題

關于JavaScript語句后面的分號問題:JavaScript自動加分號規(guī)則,有3條 當有換行符(包括含有換行符的多行注釋),并且下一個token沒法跟前面的語法匹配時,會自動補分號。 當有}時,如果缺少分號,會補分號 當程序源代碼結束時,如果缺少分號,會補分號。 利用我自己的JS語法分析工具JSi
推薦度:
導讀關于JavaScript語句后面的分號問題:JavaScript自動加分號規(guī)則,有3條 當有換行符(包括含有換行符的多行注釋),并且下一個token沒法跟前面的語法匹配時,會自動補分號。 當有}時,如果缺少分號,會補分號 當程序源代碼結束時,如果缺少分號,會補分號。 利用我自己的JS語法分析工具JSi

JavaScript自動加分號規(guī)則,有3條

  1. 當有換行符(包括含有換行符的多行注釋),并且下一個token沒法跟前面的語法匹配時,會自動補分號。
  2. 當有}時,如果缺少分號,會補分號
  3. 當程序源代碼結束時,如果缺少分號,會補分號。 

利用我自己的JS語法分析工具JSinJS(https://github.com/kissjs/JSinJS ),我求出了所有能夠出現(xiàn)在語句第一個的JS語法標記 (就是Statement的first集合),他們是:

["debugger", "try", "throw", "switch", "Identifier", "with", "return", "break", "continue", "for", "while", "do", "if", "new", "function", "(", "{", "[", "RegularExpressionLiteral", "StringLiteral", "NumericLiteral", "BooleanLiteral", "NullLiteral", "this", "!", "~", "-", "+", "--", "++", "typeof", "void", "delete", ";", "var"]

共計35個。 

我又求出了所有可以出現(xiàn)在分號之前的語法標記(即去掉分號以后的last集),他們是

["--", "++", "IdentifierName", "]", ")", "}", "RegularExpressionLiteral", "StringLiteral", "NumericLiteral", "BooleanLiteral", "NullLiteral", "Identifier", "this", "debugger", "return", "break", "continue"]

共計17個。

35*17 = 595種組合,為了方便記憶,以下我分組來討論語法歧義 。(本來用Excel弄了張表,不過表太大了不好貼出來)

首先,以下語法標記開頭的語句是絕對安全的,不會跟不加分號的上一行產生任何歧義:

var if do while for continue break return with switch throw try debugger ;

接下來我們來分組看不加分號導致的語法歧義:

  1. 第一種是++和--兩種運算符出現(xiàn)在上一行結尾的情況,下一行以以下開頭時,會產生語法歧義: 
  2. function delete void typeof new null true false NumericLiteral StringLiteral RegularExpressionLiteral ( [ { Identifier ++ -- + - ~ ! 
  3. 其中,function和delete是非常常用的statement開頭。
  4. 特別是 ++和--單獨被斷為一行的時候,因為JS的語法規(guī)則規(guī)定后自增運算不允許中間插入換行,所以++和--會被視為前自增而跟下一行連接在一起。
  5. 第二種是return作為上一行結尾的情況,下一行以以下開頭時,會產生語法歧義:
  6. function delete void typeof ( [ { Identifier ++ -- + - ~ !
  7. 同樣因為JS語法的規(guī)則不允許在return 和后面的值之間插入換行,所以return之后只要有換行符就會視為有分號,這常常會與使用者的期望不符合。
  8. 第三種是下一行以+和-開頭的情況,上一行以以下結尾是,會產生語法歧義:
  9. -- ++ IdentifierName ] ) } RegularExpressionLiteral
  10. 因為很少有語句以+或者-開頭,所以這種情況不算危險。
  11. 第四種是上一行以break、continue結尾的情況,下一行以Identifier開頭時,會產生語法歧義。
  12. 第五種是下一行以(和[開頭的情況,上一行以以下結尾是,會產生語法歧義:
  13. -- ++ IdentifierName ] ) } RegularExpressionLiteral StringLiteral NumericLiteral BooleanLiteral NullLiteral Identifier this 
  14. 這種情況非常危險(所以hax的文章中要提出這種情況應該語句前寫分號),幾乎上一行的所有情況都將導致正常期望之外的結果。
  15. 第六種是,當下一行以RegularExpressionLiteral 開頭的情況,上一行的以下結尾,會導致/被理解為除號:
  16. -- ++ IdentifierName ] ) }  RegularExpressionLiteral StringLiteral NumericLiteral BooleanLiteral NullLiteral Identifier this

總結,

  1. 在return、break、continue、后自增、后自減五種語句中,換行符可以完全替代分號的作用。
  2. var if do while for continue break return with switch throw try debugger幾種關鍵字開頭的語句,以及空語句,上一行加不加分號影響不大。
  3. 凡表達式語句和函數表達式語句,后面不加分號非常危險,情況極其復雜。
  4. 凡(和[開頭的語句,前面不加分號極度危險。

下面在通過實例代碼介紹下JavaScript中的分號問題

一般在比較懶的前臺程序員中經常會碰到一些莫名其妙的問題。

今天僅討論一下在JS中經常會碰到一些關于分號的問題。JavaScript這門語言是可以省略分號的,是因為它會換行符后如果缺少分號就會無法編譯時它會默認添加上分號,但是在一些特定情況下他是不會默認添加分號的。現(xiàn)在簡單介紹一下需要注意的幾個地方。

在這種情況時:

var x = 0
[x+1,x+2,x+3].forEach(function(){
console.log(x)
})

這種情況下會導致程序無法正常運行。JavaScript在解析這段代碼是并不會在var x = 0后換行。
在寫代碼時如果以一條語句以 ”(”  ,"[" ,"+" ,"-"  ,"/"  開始時通常在上一條語句不會默認添加分號的。所以在這種情況下盡量保持一下這種寫法,在以這些字符開始時在行首添加一個分號,這樣可以保證在別人更改上面代碼時不加分號也不會影響以下代碼運行。

var x = 0
;[x+1,x+2,x+3].forEach(function(){
console.log(x)
}) 

還有就是在涉及 return   break   continue  這種語句時盡量不要換行

return 
true;
JavaScript會解析為
return; true;
在涉及 ++ 和 -- 這一系列運算時 在作為表達式的前綴或后綴時在換行是會有一定的問題,如下情況:
var x = 0;
var y = 0;
x
++
y

JavaScript會解析為

x;++y;      而不是    x++;y;

雖然在JavaScript這門語言中  “;”  是可以省略不寫的,但是還是建議大家每句代碼后都跟上  “;”  養(yǎng)成這種良好的編碼習慣,畢竟在大多語言中不帶  “;”  的編碼適不適用的。

總結

以上所述是小編給大家介紹的JavaScript語句后面的分號問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

關于JavaScript語句后面的分號問題

關于JavaScript語句后面的分號問題:JavaScript自動加分號規(guī)則,有3條 當有換行符(包括含有換行符的多行注釋),并且下一個token沒法跟前面的語法匹配時,會自動補分號。 當有}時,如果缺少分號,會補分號 當程序源代碼結束時,如果缺少分號,會補分號。 利用我自己的JS語法分析工具JSi
推薦度:
標簽: 分號 js 問題
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top