|
以下為本人在學(xué)習(xí)js過程總結(jié)的幾點關(guān)于增強js程序的健壯性的心得,如果您覺得對你有一點的價值,那我就達到自己的目的了,如果你覺得沒有什么意義,請您也不必扔磚頭,謝謝。
(1)對于必要的參數(shù)要判斷是否被正確的傳入。
代碼示例:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
(2)根據(jù)傳入的參數(shù)類型不同做不同處理:
例如當我們要獲取一個html元素對象時,要判斷傳入的是一個id還是一個元素對象。
代碼示例:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
(3)為參數(shù)設(shè)定默認值。
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
(4)檢查傳入的參數(shù)類型。
例如:
我們要求傳入的某個參數(shù)必須為數(shù)字。
示例代碼:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
再比如可能我們需要通過參數(shù)設(shè)定一個寬度或高度值:
示例代碼:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
(5)在JS的oo編程中,如果程序要獲取當前實例名,則必須對傳入實例名做判斷。
示例代碼:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
(6)在解析xml數(shù)據(jù)之前首先要檢查傳入xml數(shù)據(jù)類型(Dom?xml字符串?文件名)及其結(jié)構(gòu)的合法性。
示例代碼:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
(7)善用try...catch語句,很多時候的錯誤我們無法屏蔽,使用try...catch可以很容易的將這些錯誤過濾掉。
比如當我們在使用userData時,很多瀏覽器不支持,使用try...catch可以簡化我們的處理。
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
歡迎大家多評論,提出更好更多的建議。
arg==undefined 改成 arg === undefined 可能會好些
var arg1=arg1||"default arg1";
這樣寫略有點問題
arg1是null 0 "" false都不行
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
三個等號表示類型也相等。JS在比較時不會自動轉(zhuǎn)換類型。
JavaScript技術(shù):“增強js程序代碼的健壯性”之我見大量示例代碼,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。