一.錯誤分類
1. 文法錯誤
也稱為解析錯誤,發生在傳統程式語言的編譯時,在JavaScript中發生在解釋時,這些錯誤是由程式碼中的意外字元直接引起的,然後就不能直接編譯/解釋,eg,在一行程式碼因缺少右括號,產生了語法錯誤。發生語法錯誤時,就不能繼續執行程式碼。在JavaScript中,只有在同一個執行緒中的程式碼會受語法錯誤的影響。在其他執行緒中的程式碼和其他外部引用的檔案中的程式碼,如果不依賴包含錯誤的程式碼,則可以繼續執行。
2. 運行時錯誤
也稱為異常(exception,在編譯期/解釋器後)。此時,問題並不出在程式碼的語法上,而是,嘗試完成的一個操作,在某些情況下是非法的。 eg.
window.openMyFile();
因不存在openMyFile()方法,瀏覽器會回傳一個異常。異常只會影響發生的線程,其他JavaScript線程即可繼續正常的執行。
二.處理錯誤
1. onerror事件處理函數
它是第一個用來協助JavaScript處理錯誤的機制。頁面上出現異常時,error事件便在window物件上觸發。 Eg.
在上述程式碼中,在頁面載入時嘗試呼叫不存在的函數,此時會引發一個異常。彈出「發生錯誤」的錯誤訊息。但是,瀏覽器的錯誤訊息也顯示出來了,如何在瀏覽器上隱藏它呢,只需onerror方法傳回一個true即可。
1) 取出錯誤訊息
onerror處理函數提供了三種資訊來確定錯誤確切的性質:
i)錯誤訊息-對於給定錯誤,瀏覽器會顯示相同的訊息;
ii)URL-在哪個文件中發生了錯誤;
行號-給定URL中發生錯誤的行號。
訪問方法見下列範例:
2) 影像載入錯誤
window對象並非唯一支援onerror事件處理函數的對象,它對圖像對像也提供支援。當一個影像因檔案不存在等原因未能成功載入時,error事件便在這個影像上觸發。讓我們來看一個例子:
上例直接在HTML中指派onerror事件處理函數。當然也可以透過腳本來分配事件處理函數,在設定影像的src特性前,必須等待頁面完全載入,程式碼如下:
注意:與window物件的onerror事件處理函數不同,image的onerror事件任何的額外資訊的參數。
3) 處理文法錯誤
onerror還能處理文法錯誤。但有一點必須注意,事件處理函數必須是頁面中第一個出現的程式碼,因為如果語法錯誤出現在設定事件處理函數之前出現,事件處理函數就沒有用了。
注意:語法錯誤會完全停止程式碼的執行。
說明:使用onerror事件處理函數的主要的問題是,它是BOM的一部分,所以,沒有任何標準能控制它的行為。因此,不同的瀏覽器使用這個事件處理錯誤的方式有明顯的不同,eg,在IE中發生error事件時,正常的程式碼會繼續執行,所有的變數和資料都保留下來,並可透過onerror事件處理函數訪問。在Mozilla中,正常的程式碼執行都會結束,同時所有的錯誤發生之前的變數和資料都被銷毀。
2. try…catch語句
ECMPScript第三版,引進了try…catch語句。 Eg.
try {
window.openFile1();
alert("成功呼叫openFile1方法");
} catch (exception) {
alert("發生異常!");
} finally {
alert("try..catch測試結束!");
}
與Java不同,ECMAScript標準在try…catch語句中只能有一個catch語句,因為JavaScript是弱型別的語言,沒辦法指明catch子句中異常的特定型別。不管錯誤是什麼類型,都由同一個catch語句處理。但Mozilla對其進行了擴展,可加多個catch語句,不建議這樣使用。
finally用於包含無論是否有異常發生都要執行的程式碼,這對關閉開啟的連結和釋放資源很有用。
1) 巢狀try…catch語句
用來處理catch子句中的錯誤問題,讓我們來看一個例子,程式碼如下:
try {
eval("a b");
} catch(oException) {
alert("發生錯誤!");
try {
var aError = new Array(100000000000000000000000000000000000000);
} catch(exception) {
alert("在catch子句中發生錯誤!");
}
} finally{
alert("完成")
}
2) Error物件
發生錯誤時,JavaScript有個Error基底類別用來拋出。它有兩個特性:
i)name-表示錯誤類型的字串
ii)message-實際的錯誤訊息。
Error物件的name對應於它的類,可以是以下值之一:
EvalError:錯誤發生在eval()函數中;
RangeError:數字值超出JavaScript可表示的範圍;
ReferenceError:使用了非法的引用;
SyntaxError:在eval()函數呼叫中發生了語法錯誤,其他的愈發錯誤由瀏覽器報告,無法透過try…catch處理;
TypeError:變數的型別不是預期所需的;
URIError:在encodeURI或decodeURI函數發生了錯誤。
3)判斷錯誤類型
可採取以下兩種方法來判斷錯誤類型,第一種根據異常的name屬性判斷,如下:
try {
eval("a b");
} catch(oException) {
if (oException.name = "SyntaxError") {
alert("發生SyntaxError!");
} else {
alert("發生其他錯誤!");
}
}
第二中採用instanceof操作符,程式碼如下:
try {
eval("a b");
} catch(oException) {
if (oException instanceof SyntaxError) {
alert("發生SyntaxError!");
} else {
alert("發生其他錯誤!");
}
}
4) 拋出異常的throw語句
在ECMAScript第三版引入,用於有目的的拋出異常,拋出的錯誤對象可為字符串、數字、布爾值或實際的對象,也可以拋出Error對象(其構造函數只有一個函數,即錯誤訊息)。 eg1. throw new Error(“錯誤產生!”);
eg2.
function addTwoNumber(a, b) {
if (arguments.length throw new Error("需要傳入兩個數字!");
}
}
try {
result = addTwoNumber(90);
} catch(oException) {
if (oException instanceof SyntaxError) {
alert("SyntaxError:" oException.message);
} else if (oException instanceof Error){
alert(oException.message);
}
}
以上就是本文所述的全部內容了,希望小夥伴們能夠喜歡。

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1
好用且免費的程式碼編輯器

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1
強大的PHP整合開發環境