JS異常處理的一個想法(sofish)_javascript技巧
可能由於網頁、瀏覽器問題、快取等原因,可能導致線上執行 js 的時候與開發環境並不一樣,會拋出例外。 js 異常基本上是前端開發工程師的家常便飯。如何記錄,並使用它,卻很少人注意。最近在考慮一個想法,基本上涉及到兩個步驟:收集和使用。
一、收集
對於error 收集這一塊,還是比較方便的,因為在各瀏覽器中都有一個介面:window.onerror,程式碼如下:
window.onerror = function(errorMessage, scriptURL, Number> >alert(errorMessage, scriptURL, lineNumber)
}
fn()
} catch(e) {
alert(e.stack)
}
二、使用 之前在支付寶的時候,線上 js 報錯會變成一個郵件,發給前端開發 team,每個人自己認領、解決。其實這是一個不錯的選擇,也解決了最基本的問題:立即回應,修復。不過也存在著一個問題,如果避免同樣的錯誤?我的初步想法是這樣的: 以URL 為單元,記錄同一個頁面的報錯:方便統一解決記錄錯誤包括:Page URL, User Agent, Script URL, Error Message 和Line Number 每個錯誤解決後,都可以在一個地方寫解決方案,看到的人可以評論、加分,最終會存檔起來,作為一個知識庫,並用有方便的api 可以使用這些知識庫的內容在開發的時候,相同頁面window.onerror 的時候,透過插件,分析Error Message 識別出類型,加上URL 的判斷,給予開發者提醒前人犯過的錯誤開發者可以訂閱知識庫上某些標籤,自動接收郵件(當然也可以根據文件註釋、mapping 等方式做更好的配對) 為什麼要這樣做?主要是為了解決下面的一些問題: 形成知識庫,開發者可以從中得到學習,特別是新人工具保證效率的提升和避免重複錯誤重複解決訂閱保證通知更具針對性
三、注意點 1. 收集的時候使用POST 發送有時候Error Message 可能會比較長,而瀏覽器的URL 長度是有限制的,如果存的錯誤不多的話,可以考慮用GET發送,但通常來說POST 可以把所有資料都傳送到後台。 2. 何時發送資料 建議在觸發 onerror 的時候發送。在第一次有這個想法的時候,嘗試在 onbeforeonload 的時候發送,但 POST 請求還沒 open 就已經被瀏覽器中斷了。 3. 存於資料庫以哪一個作為索引比較好? 通常來說以 URL 可能會比較適合多數網站。但像百姓網、淘寶等 UGC 比較多的網站,可能需要變通以記錄 URL。畢竟不同貼文不同 URL 都是同一套程式碼。 那以 Error 作為索引呢?其實無論是那種,看自己需求選擇。 4. 是否記錄所有錯誤 這個也比較適合根據需求來看。百姓網有各種亂七八糟的報錯可能都是來自到 baidu / Google 的 ad 外鏈。
四、結語 目前初步實現了一個收集的工具(sofish/stacktrace.js)和存儲方式,是否繼續,還需要時間和進一步考慮,先發出來,拋磚引玉。

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

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

SublimeText3漢化版
中文版,非常好用

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

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

C++中函數異常處理對於多執行緒環境特別重要,以確保執行緒安全性和資料完整性。透過try-catch語句,可以在出現異常時擷取和處理特定類型的異常,以防止程式崩潰或資料損壞。

C++異常處理允許建立自訂錯誤處理例程,透過拋出異常並使用try-catch區塊捕捉異常來處理運行時錯誤。 1.建立一個派生自exception類別的自訂異常類別並覆寫what()方法;2.使用throw關鍵字拋出異常;3.使用try-catch區塊捕捉異常並指定可以處理的異常類型。

遞歸呼叫中的異常處理:限制遞歸深度:防止堆疊溢位。使用異常處理:使用try-catch語句處理異常。尾遞歸優化:避免堆疊溢位。

在多執行緒C++中,例外處理遵循以下原則:及時性、執行緒安全性和明確性。在實戰中,可以透過使用mutex或原子變數來確保異常處理程式碼線程安全。此外,還要考慮異常處理程式碼的重入性、效能和測試,以確保其在多執行緒環境中安全有效地運作。

C++Lambda表達式中的異常處理沒有自己的作用域,預設不捕獲異常。要捕獲異常,可以使用Lambda表達式捕獲語法,它允許Lambda表達式捕獲其定義範圍內的變量,從而在try-catch區塊中進行異常處理。

多執行緒環境下異常處理的要點:捕捉異常:每個執行緒使用try-catch區塊捕捉異常。處理異常:在catch區塊中列印錯誤訊息或執行錯誤處理邏輯。終止執行緒:無法復原時,呼叫Thread.stop()終止執行緒。 UncaughtExceptionHandler:處理未捕獲異常,需要實作該介面並指定給執行緒。實戰案例:線程池中的異常處理,使用UncaughtExceptionHandler來處理未捕獲異常。

PHP異常處理:透過異常追蹤了解系統行為異常是PHP用來處理錯誤的機制,由異常處理程序處理異常。異常類別Exception代表一般異常,而Throwable類別代表所有異常。使用throw關鍵字拋出異常,並使用try...catch語句定義異常處理程序。在實戰案例中,透過異常處理捕獲並處理calculate()函數可能拋出的DivisionByZeroError,確保應用程式在發生錯誤時也能優雅地失敗。

在PHP中,異常處理通過try,catch,finally,和throw關鍵字實現。 1)try塊包圍可能拋出異常的代碼;2)catch塊處理異常;3)finally塊確保代碼始終執行;4)throw用於手動拋出異常。這些機制幫助提升代碼的健壯性和可維護性。
