欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的分號插入機制詳細介紹

 更新時間:2015年02月11日 11:09:07   投稿:junjie  
這篇文章主要介紹了JavaScript中的分號插入機制詳細介紹,本文講解JavaScript中各種情況下的分號插入機制,需要的朋友可以參考下

僅在}之前、一個或多個換行之后和程序輸入的結(jié)尾被插入

也就是說你只能在一行、一個代碼塊和一段程序結(jié)束的地方省略分號。

也就是說你可以寫如下代碼

復制代碼 代碼如下:

function square(x) {
    var n = +x
    return n * n
}

但是卻不可以寫的像下面代碼一樣,這樣就報錯了哦
復制代碼 代碼如下:

function area(r) {    r = +r    return Math.PI*r*r }//error

僅在隨后的輸入標記不能解析時插入

也就是說分號插入是一種錯誤校正機制??创a說話

復制代碼 代碼如下:

a = b
(f())
//能正確的解析為一條單獨的語句  單價于下面這條語句
a = b(f())

a = b
f()
//被解析為兩條獨立的語句
a = bf();//解析有誤

所以你必須得注意下一條語句的開始,從而確定你是否能夠合法的省略分號。

(、[、+、-、和/  這五個字符開始的語句,那么最好前面不要省略分號。

舉例說明一下哦

復制代碼 代碼如下:

a = b
['r', 'g', 'b'].forEach(function (key) {
    console.log(key);
});

本來你以為沒有錯誤,但是解析器卻解析成了如下語句
復制代碼 代碼如下:

a = b['r', 'g', 'b'].forEach(function (key) {
    console.log(key);
});

因為第二句語句是以[開始的,所以解析器不會在第一條語句后自動插入分號,這樣就解析成了如上所示,上面的式子解析時b['b'].forEach難道不是錯的嗎?

所以(、[、+、-、和/  這五個字符開始的語句,那么最好前面不要省略分號。

想省略分號,有經(jīng)驗的程序員會在該語句的后面跟一個聲明語句,以保證解析器解析正確。如下所示

復制代碼 代碼如下:

a = b
var x//特意在此加了聲明語句以保證a = b不會和(f())解析到一塊兒
(f())

所以如果你需要省略分號,必須檢查接下來的一行開始標記是否為上述五個字符導致解析器會禁用自動插入分號,或者你也可以在(、[、+、-、和/  這五個字符前置一個分號

省略分號導致腳本連接問題

復制代碼 代碼如下:

//file1.js
(function () {
    //......
})()

//file2.js
(function () {
    //......
})()

上述兩個文件連接時,就會被解析成如下

復制代碼 代碼如下:

(function () {
    //......
})()(function () {
    //......
})()

所以省略分號不僅需要當心當前文件的下一個標記,而且還需要當心腳本連接后可能出現(xiàn)在語句之后的任一標記。

為避免解析器解析錯誤,你可以在每個文件前綴一個額外的分號以保護腳本免受粗心連接的影響。如果文件最開始的語句以上述5個脆弱字符開關(guān),你就應該添加額外的分號前綴。

JavaScript語法限制產(chǎn)生式

JavaScript語法限制產(chǎn)生式:不允許在兩個字符之間出現(xiàn)換行。

舉例說明:

復制代碼 代碼如下:

return
{};

上述代碼就被解析成了
復制代碼 代碼如下:

return;
{}
;

自增自減運算的分號插入規(guī)則

復制代碼 代碼如下:

a
++
b

大家想想上述代碼會被解析成什么樣?說出謎底吧,因為自增運算符既可以作為前置運算符又可以作為后置運算符,但是后置運算符不能出現(xiàn)在換行之前,所以上述代碼被解析成了
復制代碼 代碼如下:

a;
++b;

分號不會作為分隔符在for循環(huán)空語句的頭部被自動插入

復制代碼 代碼如下:

for (var i = 0,total=1
    i < length
    i++) {
    total*=i;
}

像上述的代碼就會出現(xiàn)解析錯誤。

空循環(huán)體的while同樣也需要顯示的分號,否則也會導致解析錯誤

復制代碼 代碼如下:

function mytest() {
    while   (true)
}

必須寫成如下才不會報錯哦
復制代碼 代碼如下:

function mytest() {
    while   (true) ;
}

總結(jié)一下哦

1.僅在}標記之前、一行的結(jié)束和程序的結(jié)束處推導分號
2.僅在緊接著的標記不能被解析的時候推導分號
3.在以(、[、+、-、和/ 字符開頭的語句前絕不能省略分號
4.當腳本連接的時候,在腳本之間顯式的插入分號
5.在return、throw、break、continue、++或--的參數(shù)之前絕不能換行
6.分號不能作為for循環(huán)的頭部或空語句的分隔符而被推導出

相關(guān)文章

  • JavaScript的Date()方法使用詳解

    JavaScript的Date()方法使用詳解

    這篇文章主要介紹了JavaScript的Date()方法使用詳解,是JS入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-06-06
  • 談?wù)凧avaScript中的幾種借用方法

    談?wù)凧avaScript中的幾種借用方法

    我們下面來看一篇關(guān)于JavaScript中借用方法的一個詳細介紹,注意:本文假設(shè)你已經(jīng)掌握使用 call()、apply()和bind()的相關(guān)知識和它們之間的區(qū)別,希望這篇文章能夠讓各位了解到JavaScript中的借用方法吧。
    2016-08-08
  • JavaScript學習筆記(十七)js 優(yōu)化

    JavaScript學習筆記(十七)js 優(yōu)化

    在JavaScript中,我們可以使用for(;;),while(),for(in)三種循環(huán),事實上,這三種循環(huán)中for(in)的效率極差,因為他需要查詢散列鍵,只要可以就應該盡量少用。
    2010-02-02
  • 簡介JavaScript中的setHours()方法的使用

    簡介JavaScript中的setHours()方法的使用

    這篇文章主要介紹了簡介JavaScript中的setHours()方法的使用,是JS入門學習中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-06-06
  • JavaScript 閉包詳細介紹

    JavaScript 閉包詳細介紹

    這篇文章主要介紹了JavaScript 閉包的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • 使用JS CSS去除IE鏈接虛線框的三種方法

    使用JS CSS去除IE鏈接虛線框的三種方法

    本文使用JS、CSS、標簽屬性等方式去除IE鏈接上的虛線框,方法很簡單,大家可以選擇使用
    2013-11-11
  • javascript回調(diào)函數(shù)詳解

    javascript回調(diào)函數(shù)詳解

    這篇文章主要介紹了javascript回調(diào)函數(shù)的相關(guān)知識點以及用法代碼實例分析,對此有需要的朋友可以學習參考下。
    2018-02-02
  • Javascript 垃圾收集機制介紹理解

    Javascript 垃圾收集機制介紹理解

    Javascript 垃圾收集機制介紹理解,需要的朋友可以參考一下
    2013-05-05
  • JavaScript操作DOM對象詳解

    JavaScript操作DOM對象詳解

    本文詳細講解了JavaScript操作DOM對象的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • js中parseInt函數(shù)淺談

    js中parseInt函數(shù)淺談

    這篇文章介紹了Js中的parseInt函數(shù),有需要的朋友可以參考一下
    2013-07-07

最新評論