天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

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

  雖然我們平時在開發中遇到這樣情況的時候并不多,但還是有必要了解一下,JS中提供了一個DocumentFragment的機制,相信大家對這個并不陌生,它可以提供一個緩沖的機制,將DOM節點先放到內存中,當節點都構造完成后,再將DocumentFragment對象添加到頁面中,這時所有的節點都會一次渲染出來,這樣就能減少瀏覽器很多的負擔,明顯的提高頁面渲染速度。例如下面的代碼:

復制代碼 代碼如下:
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);
}


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

JavaScript技術JavaScript Tips 使用DocumentFragment加快DOM渲染速度,轉載需保留來源!

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

主站蜘蛛池模板: 久久中文骚妇内射 | 久久精品国产亚洲AV影院 | 国产亚洲视频在线观看 | 国产精品成人免费 | 免费精品在线视频 | 久久永久视频 | 暖暖视频 免费 高清 日本8 | 一道精品视频一区二区三区 | 一个人看www | 国产精品1卡二卡三卡四卡乱码 | 动漫成年美女黄漫网站 | 成人免费在线观看视频 | 97色伦在色在线播放 | 9久高清在线不卡免费无吗视频 | 一道本在线伊人蕉无码 | 高h肉文np| 久久久97丨国产人妻熟女 | 中文字幕人成乱码熟女APP | 两个奶被男人揉了一个晚上 | 人妻满熟妇AV无码区国产 | 精品久久久久久久99热 | 欧美GV肉片视频免费观看 | 在线亚洲精品国产一区麻豆 | 亚洲 欧美 日韩 精品 自拍 | 国产精品免费一区二区三区四区 | 国内国外精品影片无人区 | 久久中文字幕亚洲精品最新 | 亚洲精品成人a | 男人的天堂黄色 | 国产伦精品一区二区三区 | 青青青青青青草 | 717影院理论午夜伦不卡久久 | 久草免费视频在线观看 | 3d在线看小舞被躁视频 | 亚洲中文字幕乱码熟女在线 | 2012中文字幕在线动漫电影 | 亚洲精品婷婷无码成人A片在线 | 成人国产亚洲精品A区天堂蜜臀 | 极品美女穴 | 一个人在线观看的视频 | 在线超碰免费视频观看 |