国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

重學前端學習筆記(二十九)--JavaScript中要不要加分號?

whatsns / 1077人閱讀

摘要:一自動插入分號規則三條規則要有換行符,且下一個符號是不符合語法的,那么就嘗試插入分號。有換行符,且語法中規定此處不能有換行符,那么就自動插入分號。源代碼結束處,不能形成完整的腳本或者模塊結構,那么就自動插入分號。

筆記說明
重學前端是程劭非(winter)【前手機淘寶前端負責人】在極客時間開的一個專欄,每天10分鐘,重構你的前端知識體系,筆者主要整理學習過程的一些要點筆記以及感悟,完整的可以加入winter的專欄學習【原文有winter的語音】,如有侵權請聯系我,郵箱:kaimo313@foxmail.com。
一、自動插入分號規則 1.1、三條規則

要有換行符,且下一個符號是不符合語法的,那么就嘗試插入分號。

有換行符,且語法中規定此處不能有換行符,那么就自動插入分號。

源代碼結束處,不能形成完整的腳本或者模塊結構,那么就自動插入分號。

1.2、例子
//第一行的結尾處有換行符,接下來 void 關鍵字接在 1 之后是不合法的,根據第一條規則,會在 void 前插入換行符。
let a = 1
void function(a){
    console.log(a);
}(a);
// 根據no LineTerminator here 規則, a 的后面就要插入一個分號。
var a = 1, b = 1, c = 1;
a
++
b
++
c
// a ==> 1  b,c ==> 2
1.3、例子 no LineTerminator here 規則展示
UpdateExpression[Yield, Await]:
    LeftHandSideExpression[?Yield, ?Await]
    LeftHandSideExpression[?Yield, ?Await][no LineTerminator here]++
    LeftHandSideExpression[?Yield, ?Await][no LineTerminator here]--
    ++UnaryExpression[?Yield, ?Await]
    --UnaryExpression[?Yield, ?Await]
1.4、IIFE(立即執行的函數表達式)
(function(){
    console.log(1);
})()
(function(){
    console.log(2);
})()

// 不加分號,輸出結果
// 1   Uncaught TypeError: (intermediate value)(...) is not a function

(function(){
    console.log(1);
})();
(function(){
    console.log(2);
})()

// 加分號,輸出結果
// 1  2

// 關于這個問題,遇到過,當時排查幾十分鐘 _(:3」∠)_ , 由于我之前的是有換行,還有注釋,當時一直不理解,類似下面這樣
(function(){
    console.log(1);
})()

// 處理。。。業務
(function(){
    console.log(2);
})()
1.5、帶換行符的注釋
// 帶換行符的注釋也被認為是有換行符,return 也有 [no LineTerminator here] 規則的要求,這里會自動插入分號
function f(){
    return/*
        This is a return value.
    */1;
}
f();

// undefined
二、no LineTerminator here 規則
no LineTerminator here 規則表示它所在的結構中的這一位置不能插入換行符。

2.1、帶標簽的 continue 語句
// 不能在 continue 后插入換行。
outer:for(var j = 0; j < 10; j++)
    for(var i = 0; i < j; i++)
        continue /*no LineTerminator here*/ outter
2.2、return
function f(){
    return /*no LineTerminator here*/1;
}
2.3、后自增、后自減運算符
i/*no LineTerminator here*/++
i/*no LineTerminator here*/--
2.4、throw 和 Exception 之間
throw/*no LineTerminator here*/new Exception("error")
2.5、async 關鍵字
// 后面都不能插入換行符
async/*no LineTerminator here*/function f(){

}
const f = async/*no LineTerminator here*/x => x*x
2.6、箭頭函數
// 箭頭函數的箭頭前,也不能插入換行
const f = x/*no LineTerminator here*/=> x*x
2.7、yield
// yield 之后,不能插入換行
function *g(){
    var i = 0;
    while(true)
        yield/*no LineTerminator here*/i++;
}
三、不寫分號需要注意的情況 3.1、以括號開頭的語句
(function(a){
    console.log(a);
})()/* 這里沒有被自動插入分號 */
(function(a){
    console.log(a);
})()
3.2、以數組開頭的語句
var a = [[]]/* 這里沒有被自動插入分號 */
[3, 2, 1, 0].forEach(e => console.log(e))
3.3、以正則表達式開頭的語句
// 正則邊除號
var x = 1, g = {test:()=>0}, b = 1/* 這里沒有被自動插入分號 */
/(a)/g.test("abc")
console.log(RegExp.$1)
3.4、以 Template 開頭的語句
// 沒有自動插入分號,函數 f 被認為跟 Template 一體的,會被執行。
var f = function(){
  return "";
}
var g = f/* 這里沒有被自動插入分號 */
`Template`.match(/(a)/);
console.log(RegExp.$1)
個人總結

表示跟winter一樣,也是標分號黨。。。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/54011.html

相關文章

  • 重學前端學習筆記十九)--JavaScript要不要加分號

    摘要:一自動插入分號規則三條規則要有換行符,且下一個符號是不符合語法的,那么就嘗試插入分號。有換行符,且語法中規定此處不能有換行符,那么就自動插入分號。源代碼結束處,不能形成完整的腳本或者模塊結構,那么就自動插入分號。 筆記說明 重學前端是程劭非(winter)【前手機淘寶前端負責人】在極客時間開的一個專欄,每天10分鐘,重構你的前端知識體系,筆者主要整理學習過程的一些要點筆記以及感悟,完整...

    Sourcelink 評論0 收藏0
  • 重學前端學習筆記十九)--JavaScript要不要加分號

    摘要:一自動插入分號規則三條規則要有換行符,且下一個符號是不符合語法的,那么就嘗試插入分號。有換行符,且語法中規定此處不能有換行符,那么就自動插入分號。源代碼結束處,不能形成完整的腳本或者模塊結構,那么就自動插入分號。 筆記說明 重學前端是程劭非(winter)【前手機淘寶前端負責人】在極客時間開的一個專欄,每天10分鐘,重構你的前端知識體系,筆者主要整理學習過程的一些要點筆記以及感悟,完整...

    charles_paul 評論0 收藏0
  • 重學前端學習筆記二十七)--JavaScript的詞法

    摘要:模板語法四種詞法定義二空白符號空白符號分類或稱是,是縮進符,字符串中寫的。注意換行符會影響的兩個重要語法特性自動插入分號和規則。 筆記說明 重學前端是程劭非(winter)【前手機淘寶前端負責人】在極客時間開的一個專欄,每天10分鐘,重構你的前端知識體系,筆者主要整理學習過程的一些要點筆記以及感悟,完整的可以加入winter的專欄學習【原文有winter的語音】,如有侵權請聯系我,郵箱...

    jayzou 評論0 收藏0

發表評論

0條評論

whatsns

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<