JavaScript“盡快失敗”的原則實例詳解
我第一次聽說編碼原則中有“盡快失敗”這一條時,覺得很奇怪,為什么代碼要失?。繎?yīng)該成功才對呀。但事實上,當(dāng)代碼在遇到錯誤的時候應(yīng)該盡快的終止。為了檢測各種狀態(tài),我們需要頻繁的創(chuàng)建if語句與條件分支,而這些條件檢測的結(jié)果不是成功就是失?。╰rue&&false)。之所以會有這么多的條件檢測語句,是因為如果不在構(gòu)建過程中植入這些監(jiān)測點(checkpoint),那么瀏覽器內(nèi)核會執(zhí)行很多無用的代碼,并占用許多寶貴的CPU性能和處理時間,拖慢網(wǎng)站加載速度。
根據(jù)那些判斷結(jié)果為false的檢測語句塊放置位置的不同,有些情況下,一旦發(fā)生錯誤就迅速中止,而另外一些情況下則會在執(zhí)行了很長一段時間的無用代碼后才終止。如果我們在遍歷數(shù)組之前先檢測其長度,或是在處理DOM時先看看有沒有我們需要的class屬性,那么就可以在不滿足條件時立刻中止代碼的執(zhí)行。因為遍歷數(shù)組信息與解析DOM都是相當(dāng)耗時的工作,所以最好是在執(zhí)行這些任務(wù)之前先檢測一下,在滿足于執(zhí)行條件時及早終止。正是基于上述原因,所以我才要提倡那種“盡快失敗”的代碼。
這是我的示例代碼:
//創(chuàng)建在遇到錯誤時盡快終止的代碼
(function Salad(totalSlices,peopleCount){ //我要創(chuàng)建一個沙拉函數(shù),用來返回派對需要的總沙拉數(shù)量
"use strict";
var fairness = totalSlices * peopleCount;
return fairness;
})();
(function () {
"use strict";
var body = document.getElementsByTagName("body")[0],
//我在此閉包函數(shù)中建立了一些變量,并將其傳入salad函數(shù)以供計算
partyStarter = "starlen",
peopleCount = 18,
Salad = 6,
sliceCount = Salad * 3;
if(peopleCount > 0 && Salad >0){
//先檢測一下我們的派對有沒有人或沙拉,避免js消耗不必要的計算性能
body.innerHTML += " '<p>'"+ partyStarter +","+ Salad(peopleCount,Salad) +" '</p>' "
} else {
body.innerHTML += "<p>參加聚會的人數(shù)或沙拉果盤不足!</p>"
}
})();
在輸出某些變量信息之前,我們首先檢查確保這些變量信息是否保存于內(nèi)存之中或者某些數(shù)組內(nèi)的變量是否大于0,從而回避那些不需要執(zhí)行那些計算代碼了。這是在日常的開發(fā)工作中基礎(chǔ)且重要的易引發(fā)性能的問題,所以要重視。
以上所述是小編給大家介紹的JavaScript“盡快失敗”的原則實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
javascript實現(xiàn)五星評價代碼(源碼下載)
大家在淘寶購物之后,都會對賣家的服務(wù)進行評論,那么五星評價代碼是怎么實現(xiàn)的呢?下面小編給大家介紹基于Javascript實現(xiàn)五星評價代碼,有需要的朋友可以參考下2015-08-08
詳解TypeScript中type與interface的區(qū)別
在寫 ts 相關(guān)代碼的過程中,總能看到 interface 和 type 的身影。它們的作用好像都一樣的,相同的功能用哪一個都可以實現(xiàn),也都很好用,所以也很少去真正的理解它們之間到底有啥區(qū)別,因此本文將詳細講解二者的區(qū)別,需要的可以參考一下2022-04-04

