• DocumentFragment批量操作dom


    DocumentFragment,文档片段,不属于文档树,其parentNode为null。
    当把一个DocumentFragment节点插入文档树时,插入的不是DocumentFragment自身,
    而是它的所有子孙节点。这使得DocumentFragment成了有用的占位符,暂时存放那些
    一次插入文档的节点。它还有利于实现文档的剪切、复制和粘贴操作。

    DocumentFragment批量插入节点示例

    <ul id="list"></ul>
    // Create the fragment
    var frag = document.createDocumentFragment();
    
    // Create numerous list items, add to fragment
    for(var x = 0; x < 10; x++) {
      var li = document.createElement("li");
      li.innerHTML = "List item " + x;
      frag.appendChild(li);
    }
    
    // Mass-add the fragment nodes to the list
    listNode.appendChild(frag);

    多数情况下,DocumentFragment性能优于innerHTML,在移动端浏览器的个别情形下,
    innerHTML更优。

    高效将html字符串转换为文档碎片DocumentFragment

    //createContextualFragment高效方法
    var str='<div><strong>test</strong></div>';
    var range=document.createRange();
    range.selectNodeContents(document.documentElement); 
    var fragment =range.createContextualFragment(str);
    document.body.appendChild(fragment);
    //传统innerHTML方法,性能稍逊
    var str = '<div class="calendar" id="pager-top"><a rel="prev" href="##" class="prev">aaa</a> <span class="edit-in-place-add"></span></div> ';
    var div = document.createElement('div');
    div.innerHTML = str;
    var fragment = document.createDocumentFragment();
    // 将div上的节点转移到文档碎片上
    while((firstChild = div.firstChild)){ 
        fragment.appendChild(firstChild);
    }

    参考:http://kb.cnblogs.com/page/97567/

  • 相关阅读:
    SpringMVC学习指南【笔记6】JSTL标签、函数
    SpringMVC学习指南【笔记5】EL表达式、实现免脚本JSP页面、禁用EL计算的设置
    SpringMVC学习指南【笔记4】数据绑定、表单标签库、转换器、格式化、验证器
    序列封包和序列解包
    python 字符串分割,连接方法
    Jmeter常用插件(转)
    不同的content-type,Jmeter入参不同
    性能监测(CPU)
    正则表达式
    乱码问题
  • 原文地址:https://www.cnblogs.com/mengff/p/7707184.html
Copyright © 2020-2023  润新知