国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

Vue中fragment.js使用方法詳解

2024-05-06 15:09:59
字體:
供稿:網(wǎng)友

 大部分內(nèi)容源自 jQuery,當(dāng)然,同時(shí)也參考了 component/domify ,如果有興趣去這翻閱原始的代碼,可以到 jQuery 中查找 wrapMap;至于 domify,直接到 github 搜索即可,相關(guān)項(xiàng)目類容很少,直接看 index.js 就行了。

createDocumentFragment

如果要在一個(gè)節(jié)點(diǎn)上一次性插入多個(gè)元素怎么辦,比如說一次插入 10000 個(gè)節(jié)點(diǎn)?

最簡(jiǎn)單粗暴的方式就是:

var parent = document.getElementById('parent');for(var i = 0; i < 10000; i++) { var child = document.createElement('div'); var text = document.createTextNode('' + i); child.appendChild(text); parent.appendChild(child);}

不過眾所周知的原因,對(duì) DOM 反復(fù)操作會(huì)導(dǎo)致頁(yè)面重繪、回流,效率非常低,而且頁(yè)面可能會(huì)被卡死,這段代碼基本是沒人用的。

如果分段來進(jìn)行 DOM 操作呢,這樣就能避免卡死頁(yè)面了,js 忍者秘籍里面提到過可以用 setTimeout 來改進(jìn):

var i = 0, max = 10000;setTimeout(function addNodes() { for(var step = i + 500; i < step; i++) {  var child = document.createElement('div');  child.appendChild(document.createTextNode('' + i));  div.appendChild(child); } if(i < max) {  setTimeout(addNodes, 0); }}, 0);

當(dāng)然,更多能想到的方式應(yīng)該是,在內(nèi)存中直接操作節(jié)點(diǎn),所有節(jié)點(diǎn)都湊在一起之后再跟 DOM 樹進(jìn)行交互,把所有節(jié)點(diǎn)都串在一個(gè) div 上,然后再把 div 掛到 DOM 樹上:

var parent = document.getElementById('parent');var div = document.createElement('div');for(var i = 0; i < 10000; i++) { var child = document.createElement('div'); var text = document.createTextNode('' + i); child.appendChild(text); div.appendChild(child);}parent.appendChild(div);

如上,只跟 DOM 樹交互一次,性能方面肯定是大有改善的,不過額外插入了一個(gè) div,如果說不是跟div之類的節(jié)點(diǎn)進(jìn)行交互呢,比如在 table 中插入 th、td?

這時(shí)候,createDocumentFragment 就該出馬了,翻譯過來叫“文檔片段”,按MDN的描述:

DocumentFragments 是一些 DOM 節(jié)點(diǎn)。它們不是 DOM 樹的一部分。通常的使用場(chǎng)景是創(chuàng)建一個(gè)文檔片段,然后將創(chuàng)建的 DOM 元素插入到文檔片段中,最后把文檔片段插入到 DOM 樹中。在 DOM 樹中,文檔片段會(huì)被替換為它所有的子元素。

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

簡(jiǎn)單來說,就是上面一個(gè)例子的不需要 div 中轉(zhuǎn)版本,插入的時(shí)候,直接用其子元素替換其本身,非常完美。

雖然說,“好用的都不通用”(特別是針對(duì)某公司瀏覽器),不過這個(gè)好用的東西,甚至連 IE6 都支持。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 英吉沙县| 永胜县| 洛扎县| 龙口市| 五台县| 清苑县| 五原县| 弥渡县| 甘洛县| 大渡口区| 英吉沙县| 棋牌| 海口市| 宁武县| 红原县| 岢岚县| 得荣县| 辽源市| 湟源县| 扬州市| 平凉市| 崇明县| 昭通市| 衡水市| 阳西县| 汉中市| 平昌县| 都江堰市| 太白县| 阿拉尔市| 余姚市| 井冈山市| 清流县| 鹰潭市| 绥中县| 崇信县| 旅游| 旅游| 台中县| 太谷县| 睢宁县|