JavaScript Tips 使用DocumentFragment加快DOM渲染速度
更新時(shí)間:2010年06月28日 01:42:59 作者:
大家在開發(fā)JavaScript應(yīng)用的時(shí)候,如果遇到這種大量節(jié)點(diǎn)的情況,不妨將DocumentFragment作為一個(gè)備選的方案。
大家在使用JavaScript的時(shí)候,DOM操作是最平常不過的了, 隨著Web前端技術(shù)的發(fā)展,我們越來越多的使用JS來操作DOM元素,比如通過ajax請求獲取到數(shù)據(jù),然后更新頁面上的元素,一般情況下,這種操作我們會用類似node.appendChild()這中方式來完成。這個(gè)方法是無緩沖的,也就是說我們每次調(diào)用appendChild方法的時(shí)候,瀏覽器都會重新渲染頁面。當(dāng)然,使用這種方法也沒有什么不行,因?yàn)槲覀冊谝话闱闆r下都是對少量的DOM節(jié)點(diǎn)進(jìn)行更新,也并不會帶來太大的性能問題,但是如果大量的更新DOM節(jié)點(diǎn),那么性能的差距就會越來越明顯了。因?yàn)闉g覽器要不停的渲染頁面,尤其是一些復(fù)雜的標(biāo)簽,大量的重新渲染非常消耗性能,影響用戶體驗(yàn)。那么有什么好的方法能讓這類DOM操作的效率提高呢?
雖然我們平時(shí)在開發(fā)中遇到這樣情況的時(shí)候并不多,但還是有必要了解一下,JS中提供了一個(gè)DocumentFragment的機(jī)制,相信大家對這個(gè)并不陌生,它可以提供一個(gè)緩沖的機(jī)制,將DOM節(jié)點(diǎn)先放到內(nèi)存中,當(dāng)節(jié)點(diǎn)都構(gòu)造完成后,再將DocumentFragment對象添加到頁面中,這時(shí)所有的節(jié)點(diǎn)都會一次渲染出來,這樣就能減少瀏覽器很多的負(fù)擔(dān),明顯的提高頁面渲染速度。例如下面的代碼:
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兩種方式向頁面添加一萬個(gè)div節(jié)點(diǎn),大家可以自己實(shí)驗(yàn)一下,使用第二種方式要比第一種快很多。這里只是簡單的div標(biāo)簽的平鋪添加,如果是更加復(fù)雜的HTML標(biāo)簽或是多層的嵌套標(biāo)簽,那么性能的差距就會更加明顯。
通過上面的例子,大家在開發(fā)JavaScript應(yīng)用的時(shí)候,如果遇到這種大量節(jié)點(diǎn)的情況,不妨將DocumentFragment作為一個(gè)備選的方案。
雖然我們平時(shí)在開發(fā)中遇到這樣情況的時(shí)候并不多,但還是有必要了解一下,JS中提供了一個(gè)DocumentFragment的機(jī)制,相信大家對這個(gè)并不陌生,它可以提供一個(gè)緩沖的機(jī)制,將DOM節(jié)點(diǎn)先放到內(nèi)存中,當(dāng)節(jié)點(diǎn)都構(gòu)造完成后,再將DocumentFragment對象添加到頁面中,這時(shí)所有的節(jié)點(diǎn)都會一次渲染出來,這樣就能減少瀏覽器很多的負(fù)擔(dān),明顯的提高頁面渲染速度。例如下面的代碼:
復(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兩種方式向頁面添加一萬個(gè)div節(jié)點(diǎn),大家可以自己實(shí)驗(yàn)一下,使用第二種方式要比第一種快很多。這里只是簡單的div標(biāo)簽的平鋪添加,如果是更加復(fù)雜的HTML標(biāo)簽或是多層的嵌套標(biāo)簽,那么性能的差距就會更加明顯。
通過上面的例子,大家在開發(fā)JavaScript應(yīng)用的時(shí)候,如果遇到這種大量節(jié)點(diǎn)的情況,不妨將DocumentFragment作為一個(gè)備選的方案。
您可能感興趣的文章:
- Some tips of wmi scripting in jscript (1)
- ASP小貼士/ASP Tips javascript tips可以當(dāng)桌面
- javascript tips提示框組件實(shí)現(xiàn)代碼
- JavaScript Title、alt提示(Tips)實(shí)現(xiàn)源碼解讀
- 新鮮出爐的js tips提示效果
- jQuery懸停文字提示框插件jquery.tooltipster.js用法示例【附demo源碼下載】
- JavaScript調(diào)試的多個(gè)必備小Tips
- bootstrap tooltips在 angularJS中的使用方法
- 總結(jié)分享10個(gè)JavaScript代碼優(yōu)化小tips
相關(guān)文章
cropper js基于vue的圖片裁剪上傳功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了cropper js基于vue的圖片裁剪上傳功能的相關(guān)資料,需要的朋友可以參考下2018-03-03
Microsoft Ajax Minifier 壓縮javascript的方法
使用Microsoft AJAX 庫 (第六個(gè)預(yù)覽版) 其中有一個(gè) ajaxmin.exe 可以壓縮Js文件可以在dos 命令下 /? 查看其參數(shù)說明。2010-03-03
小程序云開發(fā)獲取不到數(shù)據(jù)庫記錄的解決方法
這篇文章主要為大家詳細(xì)介紹了小程序云開發(fā)獲取不到數(shù)據(jù)庫記錄的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05
找出字符串中出現(xiàn)次數(shù)最多的字母和出現(xiàn)次數(shù)精簡版
找出字符串中出現(xiàn)次數(shù)最多的字母和出現(xiàn)次數(shù)精簡版,有需求的朋友可以參考下2012-11-11
JavaScript進(jìn)階教程之函數(shù)的定義、調(diào)用及this指向問題詳解
這篇文章主要給大家介紹了關(guān)于JavaScript進(jìn)階教程之函數(shù)的定義、調(diào)用及this指向問題的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-09-09

