摘要:表達(dá)式用來(lái)計(jì)算出一個(gè)值,語(yǔ)句用來(lái)執(zhí)行以使某件事發(fā)生。其中,語(yǔ)句會(huì)立即退出循環(huán),強(qiáng)制繼續(xù)執(zhí)行循環(huán)后面的語(yǔ)句。在執(zhí)行語(yǔ)句之后,結(jié)果顯示。語(yǔ)句語(yǔ)句的作用是指定函數(shù)調(diào)用后的返回值。語(yǔ)句語(yǔ)句的作用是把程序運(yùn)行時(shí)產(chǎn)生的錯(cuò)誤顯式地拋出異常。
表達(dá)式在 JavaScript 中是短語(yǔ),那么語(yǔ)句就是整句命令。表達(dá)式用來(lái)計(jì)算出一個(gè)值,語(yǔ)句用來(lái)執(zhí)行以使某件事發(fā)生。從本質(zhì)上看,語(yǔ)句定義了 JavaScript 中的主要語(yǔ)法,語(yǔ)句通常使用一或多個(gè)關(guān)鍵字來(lái)完成給定任務(wù)。語(yǔ)句可以很簡(jiǎn)單,例如通知函數(shù)退出;也可以比較復(fù)雜,例如指定重復(fù)執(zhí)行某個(gè)命令的次數(shù)。下表列出了 JavaScript 大部分語(yǔ)句的語(yǔ)法和用途:
語(yǔ)句 | 語(yǔ)法 | 用途 |
---|---|---|
break | break [label]; | 退出最內(nèi)層循環(huán)或者退出 switch 語(yǔ)句,又或者退出 label 指定的語(yǔ)句 |
case | case expression: | 在 switch 語(yǔ)句中標(biāo)記一條語(yǔ)句 |
continue | continue [label]; | 重新開(kāi)始最內(nèi)層的循環(huán)或重新開(kāi)始 label 指定的循環(huán) |
debugger | debugger; | 斷點(diǎn)器調(diào)試 |
default | default; | 在 switch 中標(biāo)記默認(rèn)的語(yǔ)句 |
do-while | do statement while(expression); | while 循環(huán)的一種替代形式 |
empty | ; | 什么都不做 |
for | for(init;expr;incr) statement | 簡(jiǎn)寫(xiě)的循環(huán)結(jié)構(gòu) |
for-in | for(var in object) statement | 遍歷一個(gè)對(duì)象的屬性 |
function |
function name([param[],...]) {statement} |
聲明一個(gè)函數(shù) |
if-else |
if (expression) statement1 [else statement2] |
執(zhí)行 statement1 或者 statement2 |
label | label:statement | 給 statement 指定一個(gè)名字 label |
return | return [expression]; | 從函數(shù)返回一個(gè)值 |
switch | switch(expression){statement} | 用 case 或者 default 語(yǔ)句標(biāo)記的多分支語(yǔ)句 |
throw | throw expression; | 拋出異常 |
try |
try {statement} [catch {handler statement}] [finally {cleaup statement}] |
捕獲異常 |
use strict | "use strict" | 對(duì)腳本和函數(shù)應(yīng)用嚴(yán)格模式 |
var | var name=[=expr][,...]; | 聲明并初始化一個(gè)或多個(gè)變量 |
while | while(expression) statement | 基本的循環(huán)結(jié)構(gòu) |
with | with(object) statement | 擴(kuò)展作用域鏈 |
大多數(shù)編程語(yǔ)言中最為常用的一個(gè)語(yǔ)句就是 if-else 語(yǔ)句。以下是 if-else 語(yǔ)句的語(yǔ)法:
if (condition) statement1 [else statement2]
其中的 condition 可以是任意表達(dá)式;而且對(duì)這個(gè)表達(dá)式求值的結(jié)果不一定是布爾值。JavaScript 會(huì)自動(dòng)調(diào)用 Boolean() 轉(zhuǎn)換函數(shù)將這個(gè)表達(dá)式的結(jié)果轉(zhuǎn)換為一個(gè)布爾值。如果對(duì) condition 求值的結(jié)果是 true,則執(zhí)行 statement1,如果對(duì) condition 求值的結(jié)果是 false,則執(zhí)行 statement2。而且這兩個(gè)語(yǔ)句既可以是一行代碼,也可以是一個(gè)代碼塊(以一對(duì)花括號(hào)括起來(lái)的多行代碼)。請(qǐng)看下面的例子:
if (i > 25) console.log("Greater than 25."); // 單行語(yǔ)句 else { console.log("Less than or equal to 25."); // 代碼塊中的語(yǔ)句 }
業(yè)界普遍推崇的最佳實(shí)踐是始終使用代碼塊,即使要執(zhí)行的只有一行代碼。因?yàn)檫@樣可以消除人們的誤解,否則可能讓人分不清在不同條件下要執(zhí)行哪些語(yǔ)句。
switch 語(yǔ)句switch 語(yǔ)句與 if 語(yǔ)句的關(guān)系最為密切,而且也是在其他語(yǔ)言中普遍使用的一種流控制語(yǔ)句。JavaScript 中 switch 語(yǔ)句的語(yǔ)法與其他基于 C 的語(yǔ)言非常接近,如下所示:
switch (expression) { case value: statement break; case value: statement break; case value: statement break; case value: statement break; default: statement }
switch 語(yǔ)句中的每一種情形的含義是:“如果表達(dá)式等于這個(gè)值(value),則執(zhí)行后面的語(yǔ)句(statement)”。而 break 關(guān)鍵字會(huì)導(dǎo)致代碼執(zhí)行流跳出 switch 語(yǔ)句。如果省略 break 關(guān)鍵字,就會(huì)導(dǎo)致執(zhí)行完當(dāng)前 case 后,繼續(xù)執(zhí)行下一個(gè) case。最后的 default 關(guān)鍵字則用于在表達(dá)式不匹配前面任何一種情形的時(shí)候,也相當(dāng)于一個(gè) else 語(yǔ)句。從根本上講,switch 語(yǔ)句就是為了讓開(kāi)發(fā)人員免于編寫(xiě)像下面這樣的代碼:
if (i === 25){ console.log("25"); } else if (i === 35) { console.log("35"); } else if (i === 45) { console.log("45"); } else { console.log("Other"); }
而與此等價(jià)的switch語(yǔ)句如下所示:
switch (i) { case 25: console.log("25"); break; case 35: console.log("35"); break; case 45: console.log("45"); break; default: console.log("Other"); }
通過(guò)為每個(gè)case后面都添加一個(gè)break語(yǔ)句,就可以避免同時(shí)執(zhí)行多個(gè)case代碼的情況。假如確實(shí)需要混合幾種情形,不要忘了在代碼中添加注釋,說(shuō)明你是有意省略了break關(guān)鍵字。
雖然 JavaScript 中的 switch 語(yǔ)句借鑒自其他語(yǔ)言,但這個(gè)語(yǔ)句也有自己的特色。首先,可以在 switch 語(yǔ)句中使用任何數(shù)據(jù)類型(在很多其他語(yǔ)言中只能使用數(shù)值),無(wú)論是字符串,還是對(duì)象都沒(méi)有問(wèn)題。其次,每個(gè) case 的值不一定是常量,可以是變量,甚至是表達(dá)式。請(qǐng)看下面這兩個(gè)例子:
switch ("hello world") { case "hello" + " world": console.log("Greeting was found."); break; case "goodbye": console.log("Closing was found."); break; default: console.log("Unexpected message was found."); } var num = 25; switch (true) { case num < 0: console.log("Less than 0."); break; case num >= 0 && num <= 10: console.log("Between 0 and 10."); break; case num > 10 && num <= 20: console.log("Between 10 and 20."); break; default: console.log("More than 20."); }
switch 語(yǔ)句首先計(jì)算 switch 關(guān)鍵字后的表達(dá)式,然后按照從上到下的順序計(jì)算每個(gè) case 后的表達(dá)式,直到執(zhí)行到 case 的表達(dá)式的值與 switch 的表達(dá)式的值相等時(shí)為止。由于對(duì)每個(gè) case 的匹配操作實(shí)際上是 === 恒等運(yùn)算符比較,而不是 == 相等運(yùn)算符比較,因此,表達(dá)式和 case 的匹配并不會(huì)做任何類型轉(zhuǎn)換。
循環(huán) while 語(yǔ)句while 語(yǔ)句屬于前測(cè)試循環(huán)語(yǔ)句,也就是說(shuō),在循環(huán)體內(nèi)的代碼被執(zhí)行之前,就會(huì)對(duì)出口條件求值。因引,循環(huán)體內(nèi)的代碼有可能永遠(yuǎn)不會(huì)被執(zhí)行。以下是 while 語(yǔ)句的語(yǔ)法:
while(expression) statement
下面是一個(gè)示例:
var i = 0; while (i < 10) { i += 2; }do-while 語(yǔ)句
do-while 語(yǔ)句是一種后測(cè)試循環(huán)語(yǔ)句,即只有在循環(huán)體中的代碼執(zhí)行之后,才會(huì)測(cè)試出口條件。換句話說(shuō),在對(duì)條件表達(dá)式求值之前,循環(huán)體內(nèi)的代碼至少會(huì)被執(zhí)行一次。以下是 do-while 語(yǔ)句的語(yǔ)法:
do { statement } while (expression);
下面是一個(gè)示例:
var i = 0; do { i += 2; } while (i < 10);for 語(yǔ)句
for 語(yǔ)句也是一種前測(cè)試循環(huán)語(yǔ)句,但它具有在執(zhí)行循環(huán)之前初始化變量和定義循環(huán)后要執(zhí)行的代碼的能力。以下是 for 語(yǔ)句的語(yǔ)法:
for (initialization; expression; post-loop-expression) statement
下面是一個(gè)示例:
var count = 10; for (var i = 0; i < count; i++){ console.log(i); }
這個(gè) for 循環(huán)語(yǔ)句與下面的 while 語(yǔ)句的功能相同:
var count = 10; var i = 0; while (i < count){ console.log(i); i++; }
由于 JavaScript 中不存在塊級(jí)作用域,因此在循環(huán)內(nèi)部定義的變量也可以在外部訪問(wèn)到。例如:
var count = 10; for (var i = 0; i < count; i++){ console.log(i); } console.log(i); // 10
此外,for 語(yǔ)句中的初始化表達(dá)式、控制表達(dá)式和循環(huán)后表達(dá)式都是可選的。將這兩個(gè)表達(dá)式全部省略,就會(huì)創(chuàng)建一個(gè)無(wú)限循環(huán),例如:
// 無(wú)限循環(huán) for (;;) { doSomething(); }for-in 語(yǔ)句
for-in 語(yǔ)句是一種精準(zhǔn)的迭代語(yǔ)句,可以用來(lái)枚舉對(duì)象的屬性。以下是 for-in 語(yǔ)句的語(yǔ)法:
for (property in object) statement
下面是一個(gè)示例:
for (var propName in window) { console.log(propName); }
在這個(gè)例子中,我們使用 for-in 循環(huán)來(lái)顯示了 BOM 中 window 對(duì)象的所有屬性。每次執(zhí)行循環(huán)時(shí),都會(huì)將 window 對(duì)象中存在的一個(gè)屬性名賦值給變量 propName。這個(gè)過(guò)程會(huì)一直持續(xù)到對(duì)象中的所有屬性都被枚舉一遍為止。與 for 語(yǔ)句類似,這里控制語(yǔ)句中的 var 操作符也不是必需的。但是,為了保證使用局部變量,我們推薦上面例子中的這種做法。
JavaScript 對(duì)象的屬性沒(méi)有順序。因此,通過(guò) for-in 循環(huán)輸出的屬性名的順序是不可預(yù)測(cè)的。具體來(lái)講,所有屬性都會(huì)被返回一次,但返回的先后次序可能會(huì)因?yàn)g覽器而異。
如果表示要迭代的對(duì)象的變量值為 null 或 undefined,for-in 語(yǔ)句會(huì)拋出錯(cuò)誤。雖然 ECMAScript 5 更正了這一行為;對(duì)這種情況不再拋出錯(cuò)誤,而只是不執(zhí)行循環(huán)體。為了保證最大限度的兼容性,建議在使用 for-in 循環(huán)之前,先檢測(cè)確認(rèn)該對(duì)象的值不是 null 或 undefined。
跳轉(zhuǎn) label 語(yǔ)句使用 label 語(yǔ)句可以在代碼中添加標(biāo)簽,以便將來(lái)使用。以下是 label 語(yǔ)句的語(yǔ)法:
label: statement
下面是一個(gè)示例:
start: for (var i=0; i < count; i++) { console.log(i); }
這個(gè)例子中定義的 start 標(biāo)簽可以在將來(lái)由 break 或 continue 語(yǔ)句引用。加標(biāo)簽的語(yǔ)句一般都要與 for 語(yǔ)句等循環(huán)語(yǔ)句配合使用。
break 和 continue 語(yǔ)句break 和 continue 語(yǔ)句用于在循環(huán)中精確地控制代碼的執(zhí)行。其中,break 語(yǔ)句會(huì)立即退出循環(huán),強(qiáng)制繼續(xù)執(zhí)行循環(huán)后面的語(yǔ)句。而 continue 語(yǔ)句雖然也是立即退出循環(huán),但退出循環(huán)后會(huì)從循環(huán)的頂部繼續(xù)執(zhí)行。請(qǐng)看下面的例子:
var num = 0; for (var i=1; i < 10; i++) { if (i % 5 == 0) { break; } num++; } console.log(num); // 4
這個(gè)例子中的 for 循環(huán)會(huì)將變量 i 由1遞增至 10。在循環(huán)體內(nèi),有一個(gè) if 語(yǔ)句檢查 i 的值是否可以被 5 整除(使用求模運(yùn)算符)。如果是,則執(zhí)行 break 語(yǔ)句退出循環(huán)。另一方面,變量 num 從 0 開(kāi)始,用于記錄循環(huán)執(zhí)行的次數(shù)。在執(zhí)行 break 語(yǔ)句之后,結(jié)果顯示 4。也就是說(shuō),在變量 i 等于 5 時(shí),循環(huán)總共執(zhí)行了 4 次;而 break 語(yǔ)句的執(zhí)行,導(dǎo)致了循環(huán)在 num 再次遞增之前就退出了。如果在這里把 break 替換為 continue 的話,則可以看到另一種結(jié)果:
var num = 0; for (var i=1; i < 10; i++) { if (i % 5 == 0) { continue; } num++; } console.log(num); // 8
例子的結(jié)果顯示 8,也就是循環(huán)總共執(zhí)行了 8 次。當(dāng)變量 i 等于 5 時(shí),循環(huán)會(huì)在 num 再次遞增之前退出,但接下來(lái)執(zhí)行的是下一次循環(huán),即i的值等于 6 的循環(huán)。于是,循環(huán)又繼續(xù)執(zhí)行,直到 i 等于 10 時(shí)自然結(jié)束。而 num 的最終值之所以是 8,是因?yàn)?continue 語(yǔ)句導(dǎo)致它少遞增了一次。
break 和 continue 語(yǔ)句都可以與 label 語(yǔ)句聯(lián)合使用,從而返回代碼中特定的位置。這種聯(lián)合使用的情況多發(fā)生在循環(huán)嵌套的情況下,如下面的例子所示:
var num = 0; outermost: for (var i = 0; i < 10; i++) { for (var j = 0; j < 10; j++) { if (i == 5 && j == 5) { break outermost; } num++; } } console.log(num); // 55
在這個(gè)例子中,outermost 標(biāo)簽表示外部的 for 語(yǔ)句。如果每個(gè)循環(huán)正常執(zhí)行 10 次,則 num++ 語(yǔ)句就會(huì)正常執(zhí)行 100 次。換句話說(shuō),如果兩個(gè)循環(huán)都自然結(jié)束,num 的值應(yīng)該是 100。但內(nèi)部循環(huán)中的 break 語(yǔ)句帶了一個(gè)參數(shù):要返回到的標(biāo)簽。添加這個(gè)標(biāo)簽的結(jié)果將導(dǎo)致 break 語(yǔ)句不僅會(huì)退出內(nèi)部的 for 語(yǔ)句(即使用變量 j 的循環(huán)),而且也會(huì)退出外部的 for 語(yǔ)句(即使用變量 i 的循環(huán))。為此,當(dāng)變量 i 和 j 都等于 5 時(shí), num的值正好是 55。同樣,continue 語(yǔ)句也可以像這樣與 label 語(yǔ)句聯(lián)用,如下面的例子所示:
var num = 0; outermost: for (var i = 0; i < 10; i++) { for (var j = 0; j < 10; j++) { if (i == 5 && j == 5) { continue outermost; } num++; } } console.log(num); // 95
在這種情況下,continue 語(yǔ)句會(huì)強(qiáng)制繼續(xù)執(zhí)行循環(huán),退出內(nèi)部循環(huán),執(zhí)行外部循環(huán)。當(dāng) j 是 5 時(shí),continue 語(yǔ)句執(zhí)行,而這也就意味著內(nèi)部循環(huán)少執(zhí)行了 5 次,因此 num 的結(jié)果是 95。
雖然聯(lián)用 break、continue 和 label 語(yǔ)句能夠執(zhí)行復(fù)雜的操作,但如果使用過(guò)度,也會(huì)給調(diào)試帶來(lái)麻煩。在此,我們建議如果使用 label 語(yǔ)句,一定要使用描述性的標(biāo)簽,同時(shí)不要嵌套過(guò)多的循環(huán)。
return 語(yǔ)句return 語(yǔ)句的作用是指定函數(shù)調(diào)用后的返回值。return 語(yǔ)句的語(yǔ)法如下:
return [expression];
下面是一個(gè)示例:
function square(x) { return x*x; } // 一個(gè)包含 return 語(yǔ)句的函數(shù) square(2); // 調(diào)用結(jié)果為 4
return 語(yǔ)句只能在函數(shù)體內(nèi)出現(xiàn),如果不是的話會(huì)報(bào)語(yǔ)法錯(cuò)誤。當(dāng)執(zhí)行到 return 語(yǔ)句的時(shí)候,函數(shù)終止執(zhí)行,并返回 expression 的值給調(diào)用程序。如果沒(méi)有 return 語(yǔ)句,則函數(shù)調(diào)用僅依次執(zhí)行函數(shù)體內(nèi)的每一條語(yǔ)句直到函數(shù)結(jié)束,最后返回調(diào)用程序。這種情況下,調(diào)用表達(dá)式的結(jié)果是 undefined。return 語(yǔ)句經(jīng)常作為函數(shù)內(nèi)的最后一條語(yǔ)句出現(xiàn),但并不是說(shuō)要一定放在函數(shù)最后。return 語(yǔ)句可以多帶帶使用而不必帶有 expression,這樣的話函數(shù)也會(huì)向調(diào)用程序返回 undefined。
由于 JavaScript 可以自動(dòng)插入分號(hào),因此在 return 關(guān)鍵字和它后面的表達(dá)式之間不能有換行。
throw 語(yǔ)句throw 語(yǔ)句的作用是把程序運(yùn)行時(shí)產(chǎn)生的錯(cuò)誤顯式地拋出異常。throw 語(yǔ)句的語(yǔ)法如下:
throw expression;
expression 的值可以是任意類型的。可以拋出一個(gè)代表錯(cuò)誤碼的數(shù)字,或者包含可讀的錯(cuò)誤消息的字符串。當(dāng) JavaScript 解釋器拋出異常的時(shí)候通常采用 Error 類型和其子類型。Error 對(duì)象有一個(gè) name 屬性表示錯(cuò)誤類型,一個(gè) message 屬性用來(lái)存放傳遞給構(gòu)造函數(shù)的字符串,在下面的例子中,當(dāng)使用非法參數(shù)調(diào)用函數(shù)時(shí)就拋出一個(gè) Error 對(duì)象:
function factorial(x) { // 如果輸入?yún)?shù)是非法的,則拋出一個(gè)異常 if (x < 0) throw new Error("x不能是負(fù)數(shù)"); // 否則,計(jì)算出一個(gè)值,并正常地返回它 for(var f = 1; x > 1; f *= x, x--) /* empty */ ; return f; }
當(dāng)拋出異常時(shí),JavaScript 解釋器會(huì)立即停止當(dāng)前正在執(zhí)行的邏輯,并跳轉(zhuǎn)至就近的異常處理程序。如果沒(méi)有找到任何異常處理程序,異常就會(huì)沿著 JavaScript 方法的詞法結(jié)構(gòu)和調(diào)用棧向上傳播。最終 JavaScript 將把異常當(dāng)成程序錯(cuò)誤來(lái)處理,并報(bào)告給用戶。
try 語(yǔ)句try-catch-finally 語(yǔ)句是 JavaScript 中異常處理機(jī)制,try-catch-finally 語(yǔ)句的語(yǔ)法如下:
try {statement} [catch {handler statement}] [finally {cleaup statement}]
try 從句定義了需要處理的異常所在的代碼塊。catch 從句跟隨在 try 從句之后,當(dāng) try 塊內(nèi)某處發(fā)生了異常時(shí),調(diào)用 catch 內(nèi)的代碼邏輯。catch 從句后跟隨 finally 塊,后者中放置清理代碼,不管 try 塊中是否產(chǎn)生異常,finally 塊內(nèi)的邏輯總是會(huì)執(zhí)行。盡管 catch 和 finally 都是可選的,但 try 從句需要至少二者之一與之組成完整的語(yǔ)句。try、catch 和 finally 語(yǔ)句塊都需要使用花括號(hào)括起來(lái),這里的花括號(hào)是必需的,即使從句中只有一條語(yǔ)句也不能省略花括號(hào)。
下面的代碼詳細(xì)的說(shuō)明了 try-catch-finally 的使用目的:
try { // 通常來(lái)講,這里的代碼會(huì)從頭執(zhí)行到尾而不會(huì)產(chǎn)生任何問(wèn)題, // 但有時(shí)會(huì)拋出一個(gè)異常,要么是由 throw 語(yǔ)句直接拋出異常, // 要么是通過(guò)調(diào)用一個(gè)方法間接拋出異常 } catch(e) { // 當(dāng)且僅當(dāng) try 語(yǔ)句塊拋出了異常,才會(huì)執(zhí)行這里的代碼 // 這里可以通過(guò)局部變量 e 來(lái)獲得對(duì) Error 對(duì)象或者拋出的其他值的引用 // 這里的代碼塊可以基于某種原因處理這個(gè)異常,也可以忽略這個(gè)異常, // 還可以通過(guò) throw 語(yǔ)句重新拋出異常 } finally { // 不管 try 語(yǔ)句塊是否拋出了異常,這里的邏輯總是會(huì)執(zhí)行,終止 try 語(yǔ)句塊的方式有: // 1)正常終止,執(zhí)行完語(yǔ)句塊的最后一條語(yǔ)句 // 2)通過(guò) break、continue 或 return 語(yǔ)句終止 // 3)拋出一個(gè)異常,異常被 catch 從句捕獲 // 4)拋出一個(gè)異常,異常未被捕獲,繼續(xù)向上傳播 }其他 with 語(yǔ)句
with 語(yǔ)句的作用是將代碼的作用域設(shè)置到一個(gè)特定的對(duì)象中。with 語(yǔ)句的語(yǔ)法如下:
with (expression) statement;
定義 with 語(yǔ)句的目的主要是為了簡(jiǎn)化多次編寫(xiě)同一個(gè)對(duì)象的工作,如下面的例子所示:
var qs = location.search.substring(1); var hostName = location.hostname; var url = location.href;
上面幾行代碼都包含 location 對(duì)象。如果使用 with 語(yǔ)句,可以把上面的代碼改寫(xiě)成如下所示:
with(location){ var qs = search.substring(1); var hostName = hostname; var url = href; }
在這個(gè)重寫(xiě)后的例子中,使用 with 語(yǔ)句關(guān)聯(lián)了 location 對(duì)象。這意味著在 with 語(yǔ)句的代碼塊內(nèi)部,每個(gè)變量首先被認(rèn)為是一個(gè)局部變量,而如果在局部環(huán)境中找不到該變量的定義,就會(huì)查詢 location 對(duì)象中是否有同名的屬性。如果發(fā)現(xiàn)了同名屬性,則以 location 對(duì)象屬性的值作為變量的值。
由于大量使用 with 語(yǔ)句會(huì)導(dǎo)致性能下降,同時(shí)也會(huì)給調(diào)試代碼造成困難,因此在開(kāi)發(fā)大型應(yīng)用程序時(shí),不建議使用 with 語(yǔ)句。嚴(yán)格模式下不允許使用 with 語(yǔ)句,否則將視為語(yǔ)法錯(cuò)誤。
debugger 語(yǔ)句debugger 語(yǔ)句通常什么也不做。然而,當(dāng)瀏覽器的調(diào)試工具可用并運(yùn)行的時(shí)候,JavaScript 解釋器將會(huì)以調(diào)式模式運(yùn)行。實(shí)際上,這條語(yǔ)句用來(lái)產(chǎn)生一個(gè)斷點(diǎn)(breakpoint),JavaScript 代碼的執(zhí)行會(huì)停止在斷點(diǎn)的位置,這時(shí)可以使用調(diào)試器輸出變量的值、檢查調(diào)用棧等。例如:
function f(o) { if (o === undefined) { debugger; // 程序會(huì)停止在該位置 } // 函數(shù)的其他部分 }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/106924.html
馬上就要開(kāi)始啦這次共組織15個(gè)組隊(duì)學(xué)習(xí) 涵蓋了AI領(lǐng)域從理論知識(shí)到動(dòng)手實(shí)踐的內(nèi)容 按照下面給出的最完備學(xué)習(xí)路線分類 難度系數(shù)分為低、中、高三檔 可以按照需要參加 - 學(xué)習(xí)路線 - showImg(https://segmentfault.com/img/remote/1460000019082128); showImg(https://segmentfault.com/img/remote/...
摘要:順序結(jié)構(gòu)語(yǔ)句了解什么是流程控制語(yǔ)句流程控制語(yǔ)句可以控制程序的執(zhí)行流程。選擇結(jié)構(gòu)語(yǔ)句格式及其使用掌握語(yǔ)句的格式比較表達(dá)式語(yǔ)句體比較表達(dá)式語(yǔ)句體比較表達(dá)式語(yǔ)句體語(yǔ)句體執(zhí)行流程首先計(jì)算比較表達(dá)式看其返回值是還是,如果是,就執(zhí)行語(yǔ)句體,語(yǔ)句結(jié)束。 1.順序結(jié)構(gòu)語(yǔ)句(了解) A:什么是流程控制語(yǔ)句 流程控制語(yǔ)句:可以控制程序的執(zhí)行流程。 B:流程控制語(yǔ)句的分類 順序結(jié)構(gòu) 選擇結(jié)構(gòu) 循環(huán)...
摘要:步優(yōu)化以及其它數(shù)據(jù)庫(kù)后端掘金原文鏈接在發(fā)表了一篇簡(jiǎn)潔有效有趣和令人信服的分鐘教程描述了如何進(jìn)行優(yōu)化。關(guān)于的七種后端掘金對(duì)于的,在學(xué)習(xí)起來(lái)可能是比較亂的。 5 步優(yōu)化 MongoDB 以及其它數(shù)據(jù)庫(kù) - 后端 - 掘金原文鏈接 Jared Rosoff 在 Scale Out Camp 發(fā)表了一篇簡(jiǎn)潔、有效、有趣和令人信服的《8 分鐘 MongoDB 教程》描述了如何進(jìn)行 MongoDB...
閱讀 521·2021-10-09 09:44
閱讀 2100·2021-09-02 15:41
閱讀 3558·2019-08-30 15:53
閱讀 1836·2019-08-30 15:44
閱讀 1293·2019-08-30 13:10
閱讀 1200·2019-08-30 11:25
閱讀 1478·2019-08-30 10:51
閱讀 3370·2019-08-30 10:49