额,今天看了vue1.0关于模板渲染的知识,认识了DocumentFragment这个东西,它相当于一个节点容器,我们对他使用appendChild时,只有它的子节点会被插入进去,它本身不会插入进去,并且使用 DocumentFragment 处理节点,速度和性能远远优于直接操作 DOM。

好吧,在别人的文章中看到了一段用法

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div id="app">
<span id="b"></span>
<input type="text" id="a">
</div>
<script>
function nodeToFragment(node){
var flag=document.createDocumentFragment();
var child; while(child=node.firstChild){ flag.append(child);
}
return flag;
}
var dom=nodeToFragment(document.getElementById('app'));
console.log(dom);
</script>
</body>
</html>

  1.这里面开始不懂的是while循环里面每次一直把firstChild赋值给child,按照我的理解不是每次都是一样的么,又没有对node删除节点,经过自己实践,发现,flag.append这个方法会让被插入的child节点从父节点中移除,这个挺神奇的啊。

不过这个append方法经过查询是实验中的方法,MDN说的,之前见到过jquery的这个方法。

最新文章

  1. Linux统计文件行数
  2. javascript创建对象的方法总结
  3. 使用DD_belatedPNG让IE6支持PNG透明图片
  4. HTML和JSON的数据交互-jsonp跨域
  5. Storm入门教程 第三章Storm集群安装部署步骤、storm开发环境
  6. linux强大IDE——Geany配置说明
  7. OC修饰词 - 内存管理
  8. Linux开发工具之gdb(下)
  9. bootstrap 智能表单 demo示例
  10. CodeForces 711A Bus to Udayland
  11. Grunt打包之seajs项目【转】
  12. itextsharp html转成pdf 特殊符号异常处理
  13. IDEA外部工具配置-OpenJML篇
  14. SQL Server In-Memory OLTP Internals for SQL Server 2016
  15. windows服务项目的 安装 卸载 查看
  16. pc send instructor pc ad
  17. &lt;20180929&gt;任性的甲方
  18. C# 大型电商项目性能优化(一)
  19. 10.16 NOIP模拟赛
  20. System.currentTimeMillis() uptimeMillis elapsedRealtime 区别

热门文章

  1. 吴裕雄--天生自然TensorFlow2教程:Tensor数据类型
  2. SSM到Spring Boot-校园商铺平台:第01章 开发准备
  3. NOIp2017TG解题报告
  4. Java连载72-String类详解、多个构造方法
  5. CSS知识点小结
  6. Ubuntu下安装Docker,及Docker的一些常用命令操作
  7. [Algo] 306. Check If Linked List Is Palindrome
  8. 获取cell上按钮事件
  9. SaltStack事件驱动 – event reactor
  10. 多对多的三种创建方式-forms相关组件-钩子函数-cookie与session