日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

document.createDocumentFragment 以及创建节点速度比较

發(fā)布時間:2023/12/13 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 document.createDocumentFragment 以及创建节点速度比较 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

document.createDocumentFragment

document.createDocumentFragment()方法創(chuàng)建一個新空白的DocumentFragment對象。

DocumentFragments是DOM節(jié)點。它們不是主DOM樹的一部分。通常的用例是創(chuàng)建文檔片段,將元素附加到文檔片段,然后將文檔片段附加到DOM樹。在DOM樹中,文檔片段被其所有的子元素代替。

因為文檔片段存在于內(nèi)存中,并不在DOM樹中,所以將子元素插入到文檔片段時不會引起頁面回流(reflow)(對元素位置和幾何上的計算)。因此,使用文檔片段document fragments 通常會起到優(yōu)化性能的作用。

比如下面這個示例,給一個ul添加10000個li,先用拼接字符串的方式來實現(xiàn):

let start = Date.now() let str = '' let newUlEle = document.createElement('ul')document.body.appendChild(newUlEle)for (let i = 0; i < 10000; i++) {str += '<li>第' + i + '個子節(jié)點</li>' }newUlEle.innerHTML = strconsole.log('耗時' + (Date.now() - start) + 'ms');

多次刷新,可以看到創(chuàng)建10000個li時,渲染所需要的時間如下圖:

把上面的示例,換成append()的方式,逐個添加對應(yīng)的li:

let start = Date.now() let str = '' let newUlEle = document.createElement('ul')document.body.appendChild(newUlEle)for (let i = 0; i < 10000; i++) {let liEle = document.createElement('li')liEle.textContent = '第' + i + '個子節(jié)點'newUlEle.appendChild(liEle) }console.log('耗時:' + (Date.now() - start) + 'ms')

這種方法所費時間如下圖:

都說第二種方法要比第一種方法耗時,看上去有點像。接下來再來看createDocumentFragment的方法。可以預(yù)見的是,這種方法肯定比第二種強,但應(yīng)該沒有第一種快:

let start = Date.now() let str = '' let newUlEle = document.createElement('ul')document.body.appendChild(newUlEle)let fragment = document.createDocumentFragment()for (let i = 0; i < 10000; i++) {let liEle = document.createElement('li')liEle.textContent = '第' + i + '個子節(jié)點'fragment.appendChild(liEle) }newUlEle.appendChild(fragment)console.log('耗時:' + (Date.now() - start) + 'ms')

總結(jié)

以上是生活随笔為你收集整理的document.createDocumentFragment 以及创建节点速度比较的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。