亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在for循環(huán)中l(wèi)ength值是否需要緩存

 更新時(shí)間:2015年07月27日 14:14:07   作者:歐陽(yáng)隱  
這篇文章主要介紹了在for循環(huán)中l(wèi)ength值是否需要緩存,需要的朋友可以參考下

在for循環(huán)中是否需要緩存length值,相信很多程序猿們都糾結(jié)過(guò)此問(wèn)題,下面就這一問(wèn)題的分析請(qǐng)看下文:

在JS性能優(yōu)化中,有一個(gè)常見(jiàn)的小優(yōu)化,即

// 不緩存 
for (var i = 0; i < arr.length; i++) {
  ...
}

// 緩存
var len = arr.length;
for (var i = 0; i < len; i++) {
  ...
}

那么,我們就應(yīng)該摒棄這種寫法嗎?不是的,還有另外一種情況,必須使用這種寫法。

請(qǐng)看例子:

復(fù)制代碼 代碼如下:

var divs = document.getElementsByTagName("div"), i, div ;
for( i=0; i<divs.length; i++ ){
  div = document.createElement("div");
    document.body.appendChild("div");
}

以上代碼會(huì)導(dǎo)致無(wú)限循環(huán):第一行代碼會(huì)取得所有的div元素的nodelist,由于nodelist是動(dòng)態(tài)的,因此只要有新的div添加到頁(yè)面中,下一次的for循環(huán)就會(huì)再對(duì)divs.length求值,因此i和divs.length每次都會(huì)同時(shí)遞增,結(jié)果他們的值永遠(yuǎn)不會(huì)相等,就創(chuàng)建了一個(gè)死循環(huán)。

所以,如果想要迭代一個(gè)nodelist最好使用length屬性初始化第二個(gè)變量,然后將迭代器與該變量進(jìn)行比較,修改后的代碼如下:

復(fù)制代碼 代碼如下:

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");
}

這個(gè)例子中初始化了len,由于len中保存著divs.length在循環(huán)開(kāi)始時(shí)的一個(gè)快照,因此會(huì)避免上一個(gè)例子中出現(xiàn)的無(wú)限循環(huán)問(wèn)題,因此當(dāng)需要對(duì)nodelist進(jìn)行循環(huán)迭代的時(shí)候,使用這種方法更為保險(xiǎn)。

總結(jié):
1.將length的值進(jìn)行緩存,到底是否有利于性能優(yōu)化,是一個(gè)需要根據(jù)具體情況進(jìn)行判斷的事情,總體來(lái)講,減少對(duì)DOM的訪問(wèn)還是有好處的;
2.當(dāng)需要操作nodelist的時(shí)候,建議將length的值進(jìn)行緩存,可以避免出現(xiàn)死循環(huán)。

以上內(nèi)容就是針對(duì)是否需要緩存length值在for循環(huán)中的全部介紹,希望大家喜歡。

相關(guān)文章

  • js實(shí)現(xiàn)0ms延時(shí)定時(shí)器的幾種方式

    js實(shí)現(xiàn)0ms延時(shí)定時(shí)器的幾種方式

    本文主要介紹了js實(shí)現(xiàn)0ms延時(shí)定時(shí)器的幾種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • electron-builder打包配置詳解

    electron-builder打包配置詳解

    本文主要介紹了electron-builder打包配置詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • JS時(shí)間控制實(shí)現(xiàn)動(dòng)態(tài)效果的實(shí)例講解

    JS時(shí)間控制實(shí)現(xiàn)動(dòng)態(tài)效果的實(shí)例講解

    下面小編就為大家?guī)?lái)一篇JS時(shí)間控制實(shí)現(xiàn)動(dòng)態(tài)效果的實(shí)例講解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07
  • JavaScript中async和await的使用及隊(duì)列詳情

    JavaScript中async和await的使用及隊(duì)列詳情

    這篇文章主要介紹了JavaScript中async和await的使用及隊(duì)列詳情,主要圍繞js中async和await簡(jiǎn)單解析展開(kāi)面試中可能會(huì)問(wèn)到的關(guān)于隊(duì)列的一些場(chǎng)景和知識(shí)點(diǎn),需要的朋友可以參考一下
    2022-07-07
  • JS實(shí)現(xiàn)登錄頁(yè)面記住密碼和enter鍵登錄方法推薦

    JS實(shí)現(xiàn)登錄頁(yè)面記住密碼和enter鍵登錄方法推薦

    下面小編就為大家?guī)?lái)一篇JS實(shí)現(xiàn)登錄頁(yè)面記住密碼和enter鍵登錄方法推薦。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。
    2016-05-05
  • JS前后端實(shí)現(xiàn)身份證號(hào)驗(yàn)證代碼解析

    JS前后端實(shí)現(xiàn)身份證號(hào)驗(yàn)證代碼解析

    這篇文章主要介紹了JS前后端實(shí)現(xiàn)身份證號(hào)驗(yàn)證代碼解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • 基于bootstrap實(shí)現(xiàn)多個(gè)下拉框同時(shí)搜索功能

    基于bootstrap實(shí)現(xiàn)多個(gè)下拉框同時(shí)搜索功能

    這篇文章主要為大家詳細(xì)介紹了基于bootstrap實(shí)現(xiàn)多個(gè)下拉框同時(shí)搜索功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • JS實(shí)現(xiàn)的雪花飄落特效示例

    JS實(shí)現(xiàn)的雪花飄落特效示例

    這篇文章主要介紹了JS實(shí)現(xiàn)的雪花飄落特效,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript結(jié)合時(shí)間函數(shù)動(dòng)態(tài)操作頁(yè)面元素的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-12-12
  • JS異步編程Promise對(duì)象詳解

    JS異步編程Promise對(duì)象詳解

    本文詳細(xì)講解了JS異步編程之Promise對(duì)象,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • 如何用JavaScript檢測(cè)當(dāng)前瀏覽器是無(wú)頭瀏覽器

    如何用JavaScript檢測(cè)當(dāng)前瀏覽器是無(wú)頭瀏覽器

    這篇文章主要介紹了如何用JavaScript檢測(cè)當(dāng)前瀏覽器是無(wú)頭瀏覽器,對(duì)無(wú)頭瀏覽器感興趣的同學(xué),可以參考一下
    2021-04-04

最新評(píng)論