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

JavaScript Tips 使用DocumentFragment加快DOM渲染速度

 更新時(shí)間:2010年06月28日 01:42:59   作者:  
大家在開(kāi)發(fā)JavaScript應(yīng)用的時(shí)候,如果遇到這種大量節(jié)點(diǎn)的情況,不妨將DocumentFragment作為一個(gè)備選的方案。
大家在使用JavaScript的時(shí)候,DOM操作是最平常不過(guò)的了, 隨著Web前端技術(shù)的發(fā)展,我們?cè)絹?lái)越多的使用JS來(lái)操作DOM元素,比如通過(guò)ajax請(qǐng)求獲取到數(shù)據(jù),然后更新頁(yè)面上的元素,一般情況下,這種操作我們會(huì)用類似node.appendChild()這中方式來(lái)完成。這個(gè)方法是無(wú)緩沖的,也就是說(shuō)我們每次調(diào)用appendChild方法的時(shí)候,瀏覽器都會(huì)重新渲染頁(yè)面。當(dāng)然,使用這種方法也沒(méi)有什么不行,因?yàn)槲覀冊(cè)谝话闱闆r下都是對(duì)少量的DOM節(jié)點(diǎn)進(jìn)行更新,也并不會(huì)帶來(lái)太大的性能問(wèn)題,但是如果大量的更新DOM節(jié)點(diǎn),那么性能的差距就會(huì)越來(lái)越明顯了。因?yàn)闉g覽器要不停的渲染頁(yè)面,尤其是一些復(fù)雜的標(biāo)簽,大量的重新渲染非常消耗性能,影響用戶體驗(yàn)。那么有什么好的方法能讓這類DOM操作的效率提高呢?

  雖然我們平時(shí)在開(kāi)發(fā)中遇到這樣情況的時(shí)候并不多,但還是有必要了解一下,JS中提供了一個(gè)DocumentFragment的機(jī)制,相信大家對(duì)這個(gè)并不陌生,它可以提供一個(gè)緩沖的機(jī)制,將DOM節(jié)點(diǎn)先放到內(nèi)存中,當(dāng)節(jié)點(diǎn)都構(gòu)造完成后,再將DocumentFragment對(duì)象添加到頁(yè)面中,這時(shí)所有的節(jié)點(diǎn)都會(huì)一次渲染出來(lái),這樣就能減少瀏覽器很多的負(fù)擔(dān),明顯的提高頁(yè)面渲染速度。例如下面的代碼:

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

function CreateNodes(){
for(var i = 0;i < 10000;i++){
var tmpNode = document.createElement("div");
tmpNode.innerHTML = "test" + i + " <br />";
document.body.appendChild(tmpNode);
}
}
function CreateFragments(){
var fragment = document.createDocumentFragment();
for(var i = 0;i < 10000;i++){
var tmpNode = document.createElement("div");
tmpNode.innerHTML = "test" + i + "<br />";
fragment.appendChild(tmpNode);
}
document.body.appendChild(fragment);
}


  上面的代碼給出了兩個(gè)函數(shù),分別是用普通的DOM方法和DocumentFragement兩種方式向頁(yè)面添加一萬(wàn)個(gè)div節(jié)點(diǎn),大家可以自己實(shí)驗(yàn)一下,使用第二種方式要比第一種快很多。這里只是簡(jiǎn)單的div標(biāo)簽的平鋪添加,如果是更加復(fù)雜的HTML標(biāo)簽或是多層的嵌套標(biāo)簽,那么性能的差距就會(huì)更加明顯。
  通過(guò)上面的例子,大家在開(kāi)發(fā)JavaScript應(yīng)用的時(shí)候,如果遇到這種大量節(jié)點(diǎn)的情況,不妨將DocumentFragment作為一個(gè)備選的方案。

相關(guān)文章

  • javascript正則表達(dá)式中的replace方法詳解

    javascript正則表達(dá)式中的replace方法詳解

    replace方法的語(yǔ)法是:stringObj.replace(rgExp, replaceText) 其中stringObj是字符串(string),reExp可以是正則表達(dá)式對(duì)象(RegExp)也可以是字符串(string),replaceText是替代查找到的字符串。。
    2015-04-04
  • JavaScript indexOf()原理及使用方法詳解

    JavaScript indexOf()原理及使用方法詳解

    這篇文章主要介紹了JavaScript indexOf()原理及使用方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-07-07
  • JS實(shí)現(xiàn)鼠標(biāo)按下拖拽效果

    JS實(shí)現(xiàn)鼠標(biāo)按下拖拽效果

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)鼠標(biāo)按下拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • JavaScript判斷前綴、后綴是否是空格的方法

    JavaScript判斷前綴、后綴是否是空格的方法

    這篇文章主要介紹了JavaScript判斷前綴、后綴是否是空格的方法,涉及javascript操作字符串的正則替換、判斷與屬性操作技巧,需要的朋友可以參考下
    2015-04-04
  • JavaScript flash復(fù)制庫(kù)類 Zero Clipboard

    JavaScript flash復(fù)制庫(kù)類 Zero Clipboard

    開(kāi)發(fā)中經(jīng)常會(huì)用到復(fù)制的功能,在 IE 下實(shí)現(xiàn)比較簡(jiǎn)單。但要想做到跨瀏覽器比較困難了。
    2011-01-01
  • javascript 兼容所有瀏覽器的DOM擴(kuò)展功能

    javascript 兼容所有瀏覽器的DOM擴(kuò)展功能

    技術(shù)文章寫(xiě)得少,所以有時(shí)候想寫(xiě)點(diǎn)什么卻下不了手,不知道該寫(xiě)什么;往往到了準(zhǔn)備要寫(xiě)的時(shí)候才發(fā)現(xiàn)自己想寫(xiě)的東西其實(shí)很無(wú)聊,甚至覺(jué)得很幼稚,于是又關(guān)掉了編緝器
    2012-08-08
  • js實(shí)現(xiàn)select下拉框菜單

    js實(shí)現(xiàn)select下拉框菜單

    這篇文章主要介紹了js實(shí)現(xiàn)select下拉框菜單的詳細(xì)代碼,感興趣的小伙伴們可以參考一下
    2015-12-12
  • 收集的一些Array及String原型對(duì)象的擴(kuò)展實(shí)現(xiàn)代碼

    收集的一些Array及String原型對(duì)象的擴(kuò)展實(shí)現(xiàn)代碼

    收集的一些Array及String原型對(duì)象的擴(kuò)展實(shí)現(xiàn)代碼,學(xué)習(xí)js的朋友可以參考下。并可以自定義的對(duì)字符串與array數(shù)據(jù),進(jìn)行擴(kuò)展。
    2010-12-12
  • 微信小程序出現(xiàn)wx.navigateTo頁(yè)面不跳轉(zhuǎn)問(wèn)題的解決方法

    微信小程序出現(xiàn)wx.navigateTo頁(yè)面不跳轉(zhuǎn)問(wèn)題的解決方法

    這篇文章主要介紹了微信小程序出現(xiàn)wx.navigateTo頁(yè)面不跳轉(zhuǎn)問(wèn)題的解決方法,簡(jiǎn)單分析了微信小程序出現(xiàn)wx.navigateTo頁(yè)面不跳轉(zhuǎn)情況的原因及相應(yīng)的解決方法,需要的朋友可以參考下
    2017-12-12
  • 基于JavaScript編寫(xiě)一個(gè)在線畫(huà)板

    基于JavaScript編寫(xiě)一個(gè)在線畫(huà)板

    隨著Web技術(shù)的發(fā)展,網(wǎng)頁(yè)上的交互性變得越來(lái)越重要,一個(gè)在線畫(huà)板是一個(gè)很好的例子,本文將使用HTML5的Canvas元素和JavaScript來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的在線畫(huà)板,需要的可以了解下
    2024-01-01

最新評(píng)論