javascript window.onerror事件學(xué)習(xí)新收獲
更新時間:2007年11月02日 22:25:12 作者:
在捕獲js錯誤時,我們通常使用try{}catch(e){}的方式,然后通過e.errorMessage等方式獲取錯誤信息然后報告錯誤。但對于onerror事件可能很少問津,我們是否思考過如何報告錯誤所在的行號?如果想過這個是否也被這個問題所困擾過,是否認(rèn)為在js里不可能捕獲錯誤的行號呢?其實本人就遇到上述的幾個問題,今日讀某人寫的一段js代碼頓然發(fā)現(xiàn)了onerror事件,要說onerror這個時間也是n久以前就知道了,但對于其所帶有的三個參數(shù)和其特殊性質(zhì)卻一直沒有去了解過。經(jīng)過自己的研究測試,對onerror事件有了一些新的認(rèn)識和了解。在頁面沒有錯誤時,window.onerror事件是不存在的,也就是null(廢話!沒出錯如果onerror出現(xiàn)還正常嗎?)我們一般通過函數(shù)名傳遞的方式(引用的方式)將要執(zhí)行的操作函數(shù)傳遞給onerror事件,如window.onerror=reportError;window.onerror=function(){alert('error')},但我們可能不知道該事件觸發(fā)時還帶有三個默認(rèn)的參數(shù),他們分別是錯誤信息,錯誤頁面的url和錯誤行號。要知道這個可是事件,就如onclick和onmouseover等事件一樣,但它是有參數(shù)。我們可以這樣測試。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
首先將testError方法綁定給onerror事件,然后在test方法里觸發(fā)一個錯誤,在IE中執(zhí)行時我們發(fā)現(xiàn)如下提示:
---------------------------
Microsoft Internet Explorer
---------------------------
參數(shù)個數(shù):3個
參數(shù)1:'error' 未定義
參數(shù)2:file://E:\yanwei\test\testError.html
參數(shù)3:14
---------------------------
確定
---------------------------
可以發(fā)現(xiàn),當(dāng)出錯時函數(shù)testError捕獲到了三個參數(shù)。通過將函數(shù)綁定到onerror事件就可以在頁面出錯時捕獲以上三個參數(shù)。
在測試中還發(fā)現(xiàn)以下一些問題:
1、通過在函數(shù)末尾加上return true,可以在函數(shù)出錯時不會彈出系統(tǒng)的錯誤信息(IE)。
2、如果頁面出現(xiàn)多次錯誤,只捕獲第一次錯誤并進(jìn)行處理然后終止后面程序的執(zhí)行。
3、onerror事件并不能捕獲所有的錯誤,只能捕獲函數(shù)外或函數(shù)內(nèi)錯誤(??這個是什么意思,可不是開玩笑呢),如 adasdf;
function test(){
aaaa;
}
可以捕獲到adasdf未定義的錯誤
function test(){
aaaa;
}
可以捕獲到aaaa未定義的錯誤,而對于functiona test(){}或function test()dd{} 的錯誤卻不能捕獲而會直接彈出系統(tǒng)錯誤信息。
4、onerror在IE和FF等瀏覽器執(zhí)行方式是一樣的,而且都包含這三個參數(shù)。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
首先將testError方法綁定給onerror事件,然后在test方法里觸發(fā)一個錯誤,在IE中執(zhí)行時我們發(fā)現(xiàn)如下提示:
---------------------------
Microsoft Internet Explorer
---------------------------
參數(shù)個數(shù):3個
參數(shù)1:'error' 未定義
參數(shù)2:file://E:\yanwei\test\testError.html
參數(shù)3:14
---------------------------
確定
---------------------------
可以發(fā)現(xiàn),當(dāng)出錯時函數(shù)testError捕獲到了三個參數(shù)。通過將函數(shù)綁定到onerror事件就可以在頁面出錯時捕獲以上三個參數(shù)。
在測試中還發(fā)現(xiàn)以下一些問題:
1、通過在函數(shù)末尾加上return true,可以在函數(shù)出錯時不會彈出系統(tǒng)的錯誤信息(IE)。
2、如果頁面出現(xiàn)多次錯誤,只捕獲第一次錯誤并進(jìn)行處理然后終止后面程序的執(zhí)行。
3、onerror事件并不能捕獲所有的錯誤,只能捕獲函數(shù)外或函數(shù)內(nèi)錯誤(??這個是什么意思,可不是開玩笑呢),如 adasdf;
function test(){
aaaa;
}
可以捕獲到adasdf未定義的錯誤
function test(){
aaaa;
}
可以捕獲到aaaa未定義的錯誤,而對于functiona test(){}或function test()dd{} 的錯誤卻不能捕獲而會直接彈出系統(tǒng)錯誤信息。
4、onerror在IE和FF等瀏覽器執(zhí)行方式是一樣的,而且都包含這三個參數(shù)。
相關(guān)文章
javascript刪除一個html元素節(jié)點(diǎn)的方法
這篇文章主要介紹了javascript刪除一個html元素節(jié)點(diǎn)的方法,可通過獲取父節(jié)點(diǎn)再查找并刪除子節(jié)點(diǎn)來實現(xiàn)該功能,具有一定的參考借鑒價值,需要的朋友可以參考下2014-12-12詳解JavaScript中js對象與JSON格式字符串的相互轉(zhuǎn)換
本篇文章主要介紹了JavaScript中js對象與JSON格式字符串的相互轉(zhuǎn)換,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-02-02HTML+CSS+JavaScript實現(xiàn)可拖拽模態(tài)框
這篇文章主要為大家詳細(xì)介紹了HTML+CSS+JavaScript實現(xiàn)可拖拽模態(tài)框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07JS生態(tài)系統(tǒng)加速探索Draft-js?emoji插件功能及使用探索
這篇文章主要介紹了JS生態(tài)系統(tǒng)加速探索Draft-js?emoji插件功能使用探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01如何使用Bootstrap的modal組件自定義alert,confirm和modal對話框
本文我將為大家介紹Bootstrap中的彈出窗口組件Modal,此組件簡單易用,效果大氣漂亮且很實用,感興趣的朋友一起學(xué)習(xí)吧2016-03-03JavaScript實現(xiàn)簡單網(wǎng)頁版計算器
這篇文章主要介紹了JavaScript實現(xiàn)簡單網(wǎng)頁版計算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08javascript貪吃蛇游戲設(shè)計與實現(xiàn)
這篇文章主要為大家詳細(xì)介紹了javascript貪吃蛇游戲設(shè)計與實現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09js 獲取、清空input type="file"的值示例代碼
本篇文章主要是對js獲取、清空input type="file"的值的示例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02