色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

大家在使用JavaScript的時候,DOM操作是最平常不過的了, 隨著Web前端技術(shù)的發(fā)展,我們越來越多的使用JS來操作DOM元素,比如通過ajax請求獲取到數(shù)據(jù),然后更新頁面上的元素,一般情況下,這種操作我們會用類似node.appendChild()這中方式來完成。這個方法是無緩沖的,也就是說我們每次調(diào)用appendChild方法的時候,瀏覽器都會重新渲染頁面。當(dāng)然,使用這種方法也沒有什么不行,因為我們在一般情況下都是對少量的DOM節(jié)點進(jìn)行更新,也并不會帶來太大的性能問題,但是如果大量的更新DOM節(jié)點,那么性能的差距就會越來越明顯了。因為瀏覽器要不停的渲染頁面,尤其是一些復(fù)雜的標(biāo)簽,大量的重新渲染非常消耗性能,影響用戶體驗。那么有什么好的方法能讓這類DOM操作的效率提高呢?

  雖然我們平時在開發(fā)中遇到這樣情況的時候并不多,但還是有必要了解一下,JS中提供了一個DocumentFragment的機(jī)制,相信大家對這個并不陌生,它可以提供一個緩沖的機(jī)制,將DOM節(jié)點先放到內(nèi)存中,當(dāng)節(jié)點都構(gòu)造完成后,再將DocumentFragment對象添加到頁面中,這時所有的節(jié)點都會一次渲染出來,這樣就能減少瀏覽器很多的負(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);
}


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

JavaScript技術(shù)JavaScript Tips 使用DocumentFragment加快DOM渲染速度,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 阳新县| 平谷区| 鹰潭市| 唐河县| 汨罗市| 旬邑县| 特克斯县| 永嘉县| 阿勒泰市| 汾阳市| 张北县| 武宣县| 新昌县| 甘德县| 拉孜县| 黄石市| 迁安市| 美姑县| 贵港市| 永善县| 临城县| 武穴市| 松阳县| 南召县| 明光市| 闽清县| 南皮县| 边坝县| 思南县| 炎陵县| 郑州市| 五家渠市| 博野县| 五家渠市| 乌鲁木齐县| 新邵县| 会泽县| 龙井市| 巧家县| 永寿县| 张掖市|