在for循環(huán)中l(wèi)ength值是否需要緩存
在for循環(huán)中是否需要緩存length值,相信很多程序猿們都糾結(jié)過此問題,下面就這一問題的分析請看下文:
在JS性能優(yōu)化中,有一個常見的小優(yōu)化,即
// 不緩存 for (var i = 0; i < arr.length; i++) { ... } // 緩存 var len = arr.length; for (var i = 0; i < len; i++) { ... }
那么,我們就應(yīng)該摒棄這種寫法嗎?不是的,還有另外一種情況,必須使用這種寫法。
請看例子:
var divs = document.getElementsByTagName("div"), i, div ;
for( i=0; i<divs.length; i++ ){
div = document.createElement("div");
document.body.appendChild("div");
}
以上代碼會導(dǎo)致無限循環(huán):第一行代碼會取得所有的div元素的nodelist,由于nodelist是動態(tài)的,因此只要有新的div添加到頁面中,下一次的for循環(huán)就會再對divs.length求值,因此i和divs.length每次都會同時遞增,結(jié)果他們的值永遠不會相等,就創(chuàng)建了一個死循環(huán)。
所以,如果想要迭代一個nodelist最好使用length屬性初始化第二個變量,然后將迭代器與該變量進行比較,修改后的代碼如下:
var divs = document.getElementsByTagName("div"), i, div ,len ;
for(i=0;len=divs.length;i<len;i++){
div = document.createElement("div");
document.body.appendChild("div");
}
這個例子中初始化了len,由于len中保存著divs.length在循環(huán)開始時的一個快照,因此會避免上一個例子中出現(xiàn)的無限循環(huán)問題,因此當(dāng)需要對nodelist進行循環(huán)迭代的時候,使用這種方法更為保險。
總結(jié):
1.將length的值進行緩存,到底是否有利于性能優(yōu)化,是一個需要根據(jù)具體情況進行判斷的事情,總體來講,減少對DOM的訪問還是有好處的;
2.當(dāng)需要操作nodelist的時候,建議將length的值進行緩存,可以避免出現(xiàn)死循環(huán)。
以上內(nèi)容就是針對是否需要緩存length值在for循環(huán)中的全部介紹,希望大家喜歡。
相關(guān)文章
JavaScript中async和await的使用及隊列詳情
這篇文章主要介紹了JavaScript中async和await的使用及隊列詳情,主要圍繞js中async和await簡單解析展開面試中可能會問到的關(guān)于隊列的一些場景和知識點,需要的朋友可以參考一下2022-07-07JS實現(xiàn)登錄頁面記住密碼和enter鍵登錄方法推薦
下面小編就為大家?guī)硪黄狫S實現(xiàn)登錄頁面記住密碼和enter鍵登錄方法推薦。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。2016-05-05基于bootstrap實現(xiàn)多個下拉框同時搜索功能
這篇文章主要為大家詳細介紹了基于bootstrap實現(xiàn)多個下拉框同時搜索功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07如何用JavaScript檢測當(dāng)前瀏覽器是無頭瀏覽器
這篇文章主要介紹了如何用JavaScript檢測當(dāng)前瀏覽器是無頭瀏覽器,對無頭瀏覽器感興趣的同學(xué),可以參考一下2021-04-04