克隆节点是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://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.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‘) ) ???????}) ???</script></body></html>
Jquery浅克隆与深克隆
原文地址:https://www.cnblogs.com/liyuspace/p/9543725.html
知识推荐
- HTML 特殊符号编码对照表
- 网页返回数据的逻辑梳理
- 谈谈在 .Net 平台上的 软件生态 和 软件生产力
- JSP隐式对象
- 使用Jmeter测试WebService接口
- css
- js实现双向链表
- php函数
- 使用jQuery快速高效制作网页交互特效——07 第七章 ?jQuery中的事件与动画
- [转]idea导入eclipse的web项目
- JSONObject的parseArray方法作用。
- thinkphp模版调用函数方法
- htmlunit ?模拟登录 无验证码
- http 与 https
- hibernate.zzh
- 七牛云徐晶:基于 WebRTC 架构的直播课堂实践
- AngularJS ?src ?ng-src的区别
- nginx服务器http重定向到https的正确写法