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