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與CSS復(fù)習(xí)(《精通javascript》)
js和css結(jié)合來產(chǎn)生醒目的交互效果,我們可以快速的訪問元素自身的樣式屬性2010-06-06js判斷復(fù)選框是否選中及選中個數(shù)的實現(xiàn)代碼
下面小編就為大家?guī)硪黄猨s判斷復(fù)選框是否選中及選中個數(shù)的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05JavaScript 判斷數(shù)據(jù)類型的4種方法
這篇文章主要介紹了JavaScript 判斷數(shù)據(jù)類型的4種方法,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下2020-09-09JavaScript通過代碼調(diào)用Flash顯示的方法
這篇文章主要介紹了JavaScript通過代碼調(diào)用Flash顯示的方法,實例分析了JavaScript通過flash插件swfobject.js調(diào)用flash顯示的具體操作技巧,需要的朋友可以參考下2016-02-02javascript ES6 Template String模板字符串使用方法
這篇文章主要介紹了javascript ES6 模板字符串(Template String)是增強版的字符串,用反引號(`)標(biāo)識,它可以當(dāng)作普通字符串使用,也可以用來定義多行字符串,或者在字符串中嵌入變量,需要的朋友可以參考下2023-06-06