重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
1、实现点击按钮,复制文本框中的的内容 。
创新互联专注为客户提供全方位的互联网综合服务,包含不限于网站建设、网站设计、肃南裕固族自治网络推广、小程序定制开发、肃南裕固族自治网络营销、肃南裕固族自治企业策划、肃南裕固族自治品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联为所有大学生创业者提供肃南裕固族自治建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com
2、复制专题地址和 url 地址,传给 QQ/MSN 上的好友。
3、直接复制 url。
4、点击文本框时,复制文本框里面的内容。
5、复制文本框或者隐藏域中的内容。
6、复制 span 标记中的内容。
jQuery中的$.extend深拷贝,这种方式会完全拷贝所有数据,优点是B与A不会相互依赖(A,B完全脱离关联), 缺点是拷贝的速度更慢,代价更大。
jquery中的深拷贝:
数组深拷贝是将数组浅拷贝与对象深拷贝结合后得到的解决方案:
jQuery 代码:
$.map( [obj1,obj2,obj3], function(obj){
return $.extend(true,{},obj);//返回对象的深拷贝
});
如何实现数组深拷贝和浅拷贝?
1.背景介绍
javascript分原始类型与引用类型。Array是引用类型,直接用“=”号赋值的话,只是把源数组的地址(或叫指针)赋值给目的数组,并没有实现数组的数据的拷贝。这种方式的实现属于浅拷贝。
深拷贝是开辟新的储存空间,两个对象对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性。
2.知识剖析
一维数组的深拷贝方法:slice()和concat()
slice()的使用方法
slice()语法:arrayObj.slice(start,)
slice方法是通过参数start和end的传入值来返回数组中的一段,该方法不对原数组进行操作,而是返回一个子数组
start:必需。规定从何处开始选取。如果是负数,那么它规定从数组尾部开始算起的位置。也就是说,-1 指最后一个元素,-2 指倒数第二个元素,以此类推。
end:可选。规定从何处结束选取。该参数是数组片断结束处的数组下标。如果没有指定该参数,那么切分的数组包含从 start 到数组结束的所有元素。如果这个参数是负数,那么它规定的是从数组尾部开始算起的元素。
返回值:返回一个新的数组,包含从 start 到 end (不包括该元素)的 arrayObject 中的元素(如果 end 未被规定,那么 slice() 方法会选取从 start 到数组结尾的所有元素)。
concat()的使用方法
concat()语法:arrayObject.concat(arrayX,arrayX,......,arrayX)
arrayX:必需,可以是具体的值,也可以是数组对象。可以是任意多个。
concat() 方法用于连接两个或多个数组。 该方法不会改变现有的数组,而仅仅会返回一个新的数组。如果要进行 concat() 操作的参 数是数组,那么添加的是数组中的元素,而不是数组。
3.常见问题
1、jquery中数组深拷贝办法
语法:jQuery.extend( [deep ], target, object1 [, objectN ] )
将两个或更多对象的内容合并到第一个对象。
deep:可选。 Boolean类型 指示是否深度合并对象,默认为false。如果该值为true,且多个对象的某个同名属性也都是对象,则该"属性对象"的属性也将进行合并。
2、什么是深拷贝?
深拷贝:指的是拷贝一个对象时,不仅仅把对象的引用进行复制,还把该对象引用的值也一起拷贝。这样进行深拷贝后的拷贝对象就和源对象互相独立,其中任何一个对象的改动都不会对另外一个对象造成影响。举个例子,一个人叫张三,然后使用克隆技术以张三来克隆另外一个人叫李四,这样张三和李四就是相互独立的,不管张三缺胳膊还是李四少腿了都不会影响另外一个人。在.NET领域,值对象就是典型的例子,如int, Double以及结构体和枚举等。
3、什么是浅拷贝呢?
浅拷贝:指的是拷贝一个对象时,仅仅拷贝对象的引用进行拷贝,但是拷贝对象和源对象还是引用同一份实体。此时,其中一个对象的改变都会影响到另一个对象。例如,一个人一开始叫张三,后来改名字为张老三了,可是他们还是同一个人,不管张三缺胳膊还是张老三少腿,都反应在同一个人身上。在.NET中引用类型就是一个例子。
4 解决方案
jquery.extend()
语法:jQuery.extend( [deep ], target, object1 [, objectN ] )
将两个或更多对象的内容合并到第一个对象。
deep:可选。 Boolean类型 指示是否深度合并对象,默认为false。如果该值为true,且多个对象的某个同名属性也都是对象,则该"属性对象"的属性也将进行合并。
5.编码实战
6.扩展思考
slice和concat对数组深拷贝的局限性
slice和concat这两个方法,仅适用于对不包含引用对象的一维数组的深拷贝。对于数组内部存在对象和数组,当改变对象属性和内部数组的元素后,深拷贝的数组同样也发生了改变。