欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript“盡快失敗”的原則實例詳解

 更新時間:2016年10月08日 10:10:45   作者:畫個女孩陪著我  
我第一次聽說編碼原則中有“盡快失敗”這一條時,覺得很奇怪,為什么代碼要失?。繎?yīng)該成功才對呀。下面小編通過實例代碼給大家介紹js 盡快失敗的原則,一起看看吧

我第一次聽說編碼原則中有“盡快失敗”這一條時,覺得很奇怪,為什么代碼要失???應(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可迭代對象詳細(xì)介紹

    JavaScript可迭代對象詳細(xì)介紹

    ES6中引入了迭代器與可迭代對象的概念,并且提供了對可迭代對象的相關(guān)支持,如for...of循環(huán),Map(iterable)構(gòu)造器,展開語法...等。讓我們對數(shù)組外的數(shù)據(jù)集合的遍歷操作也得到極大簡化
    2022-06-06
  • javascript與CSS復(fù)習(xí)(《精通javascript》)

    javascript與CSS復(fù)習(xí)(《精通javascript》)

    js和css結(jié)合來產(chǎn)生醒目的交互效果,我們可以快速的訪問元素自身的樣式屬性
    2010-06-06
  • js判斷復(fù)選框是否選中及選中個數(shù)的實現(xiàn)代碼

    js判斷復(fù)選框是否選中及選中個數(shù)的實現(xiàn)代碼

    下面小編就為大家?guī)硪黄猨s判斷復(fù)選框是否選中及選中個數(shù)的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • JavaScript RegExp 對象用法詳解

    JavaScript RegExp 對象用法詳解

    這篇文章主要介紹了JavaScript RegExp 對象用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • JavaScript 判斷數(shù)據(jù)類型的4種方法

    JavaScript 判斷數(shù)據(jù)類型的4種方法

    這篇文章主要介紹了JavaScript 判斷數(shù)據(jù)類型的4種方法,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • JavaScript通過代碼調(diào)用Flash顯示的方法

    JavaScript通過代碼調(diào)用Flash顯示的方法

    這篇文章主要介紹了JavaScript通過代碼調(diào)用Flash顯示的方法,實例分析了JavaScript通過flash插件swfobject.js調(diào)用flash顯示的具體操作技巧,需要的朋友可以參考下
    2016-02-02
  • jQuery獲取隨機顏色的實例代碼

    jQuery獲取隨機顏色的實例代碼

    這篇文章主要介紹了jQuery獲取隨機顏色的實例代碼,非常不錯,具有一定的參考借鑒價值,感興趣的朋友跟隨腳本之家小編來學(xué)習(xí)吧
    2018-05-05
  • javascript ES6 Template String模板字符串使用方法

    javascript ES6 Template String模板字符串使用方法

    這篇文章主要介紹了javascript ES6 模板字符串(Template String)是增強版的字符串,用反引號(`)標(biāo)識,它可以當(dāng)作普通字符串使用,也可以用來定義多行字符串,或者在字符串中嵌入變量,需要的朋友可以參考下
    2023-06-06
  • bootstrap按鈕插件(Button)使用方法解析

    bootstrap按鈕插件(Button)使用方法解析

    這篇文章主要為大家詳細(xì)解析了bootstrap按鈕插件Button使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • js 數(shù)據(jù)類型判斷的方法

    js 數(shù)據(jù)類型判斷的方法

    這篇文章主要介紹了js 數(shù)據(jù)類型判斷的方法,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下
    2020-12-12

最新評論