DOM拷贝clone()
来源:互联网 发布:淘宝实体娃娃是真的吗 编辑:程序博客网 时间:2024/06/07 17:49
克隆节点是DOM的常见操作,jQuery提供一个clone方法,专门用于处理dom的克隆
.clone()方法深度 复制所有匹配的元素集合,包括所有匹配元素、匹配元素的下级元素、文字节点。
clone方法比较简单就是克隆节点,但是需要注意,如果节点有事件或者数据之类的其他处理,我们需要通过clone(ture)传递一个布尔值ture用来指定,这样不仅仅只是克隆单纯的节点结构,还要把附带的事件与数据给一并克隆了
例如:
HTML部分<div></div>JavaScript部分$("div").on('click', function() {//执行操作})//clone处理一$("div").clone() //只克隆了结构,事件丢失//clone处理二$("div").clone(true) //结构、事件与数据都克隆
使用上就是这样简单,使用克隆的我们需要额外知道的细节:
- clone()方法时,在将它插入到文档之前,我们可以修改克隆后的元素或者元素内容,如右边代码我 $(this).clone().css('color','red') 增加了一个颜色
- 通过传递true,将所有绑定在原始元素上的事件处理函数复制到克隆元素上
- clone()方法是jQuery扩展的,只能处理通过jQuery绑定的事件与数据
- 元素数据(data)内对象和数组不会被复制,将继续被克隆元素和原始元素共享。深复制的所有数据,需要手动复制每一个
- <!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title></title>
<script src="http://libs.baidu.com/jquery/1.9.1/jquery.js"></script>
<style>
.left,
.right {
width: 300px;
height: 120px;
}
.left div,
.right div {
width: 100px;
height: 90px;
padding: 5px;
margin: 5px;
float: left;
border: 1px solid #ccc;
background: #bbffaa;
}
</style>
</head>
<body>
<h2>通过clone克隆元素</h2>
<div class="left">
<div class="aaron1">点击,clone浅拷贝</div>
<div class="aaron2">点击,clone深拷贝,可以继续触发创建</div>
</div>
<script type="text/javascript">
//只克隆节点
//不克隆事件
$(".aaron1").on('click', function() {
$(".left").append( $(this).clone().css('color','red') )
})
</script>
<script type="text/javascript">
//克隆节点
//克隆事件
$(".aaron2").on('click', function() {
console.log(1)
$(".left").append( $(this).clone(true).css('color','blue') )//this指当前事件 .aaron2这个事件会被clone
})
</script>
</body>
</html>
阅读全文
0 0
- DOM拷贝clone()
- DOM拷贝clone()
- java 深浅拷贝 clone
- clone浅拷贝
- html dom clone
- Clone 分浅拷贝和深拷贝
- Java中的clone() 深拷贝 浅拷贝
- php5中的clone 浅拷贝 深拷贝
- clone方法 --深拷贝与浅拷贝
- java中的clone( ) -- 浅拷贝 | 深拷贝
- 浅拷贝和Clone方法
- 图的深拷贝 Clone Graph
- java.util.ArrayList.clone()是浅层拷贝
- 数组的拷贝及对象clone
- 深入理解java拷贝机制(clone)
- java中的Clone(深拷贝,浅拷贝)
- Java&&Clone之浅拷贝和深拷贝
- 深拷贝和浅拷贝(clone用法)
- 【POJ1287】Networking(最小生成树)
- linux总结 三
- 434. Number of Segments in a String
- 2017年8月3日- 星期四
- 二叉排序树(Binary Sort Tree)的查找递归算法
- DOM拷贝clone()
- js高级程序设计(第三版)第二章
- spark-2.2.0源码阅读环境的搭建
- SpringMVC4.3x教程之五SpringMVC表单标签的使用
- Linux系统中的临时文件
- 深入解析Spring架构与设计原理-AOP
- 推广下自己的JAVA开源游戏服务端框架
- XML利用dom4j进行增删查改等方法
- html javascript函数(三)