一:在Javascript里,如果克隆对象是基本类型,我们直接赋值就可以了:
var sStr = "kingwell"; var cStr = sStr; alert(cStr);//输出kingwell sStr = "abc"; alert(cStr);//输出kingwell;
?把一个值赋给另一个变量时,当那个变量的值改变的时候,另一个值不会受到影响。
?
二:如果不是基本类型,那就有所有不同了:
var aArr = [0,1,2,3]; var m = aArrr; alert(m);//输出1,2,3 aArr=[1,1,2,3]; alert(m);//输出1,1,2,3;这个值改变了,因为m只是aArr的一个引用,如果aArr的值改变了,那么m也会相应的改变。
?如果我们想克隆一个数组,最简单的办法:
var aArr = [0,1,2,3]; var m = aArr.slice(0); aArr = [3,2,1,0]; alert(m);//输出0,1,2,3,这时虽然aArr中的值已经改变,但是因为使用slice方法已经创建一个新的数组。?
我们可以创建一个函数来克隆所有对象:
?
function clone(obj) { var o; if (typeof obj == "object") { if (obj === null) { o = null; } else { if (obj instanceof Array) { o = []; for (var i = 0, len = obj.length; i < len; i++) { o.push(clone(obj[i])); } } else { o = {}; for (var j in obj) { o[j] = clone(obj[j]); } } } } else { o = obj; } return o; }
?三:节点克隆:
var p = document.getElementsByTagName("p")[0]; var cP = p.cloneNode();//克隆p节点 var cP = p.cloneNode(true);//克隆p节点,深度克隆,克隆节点以及节点下面的子内容。
1 楼
chenweick
2012-09-11
数组克隆的话建议用var m=aArr.contact()来实现,这样可以保留aArr本身
2 楼
Lovic
2012-09-11
ttttttttttttttttttttt
3 楼
kingwell.leng
2012-09-11
chenweick 写道
数组克隆的话建议用var m=aArr.contact()来实现,这样可以保留aArr本身
现在aArr也没有变,如果不刻意改变的话,你说的是concat吧,没这个函数contact吧
4 楼
lazy_
2012-09-13
lazy_ 写道
引用
<script>
var aArr = [0,1,2,3];
var m = aArr;
alert(m);//输出1,2,3
aArr=[3,2,1,0];
alert(m);//输出3,2,1,0;这个值改变了,因为m只是aArr的一个引用,如果aArr的值改变了,那么m也会相应的改变。
</script>
var aArr = [0,1,2,3];
var m = aArr;
alert(m);//输出1,2,3
aArr=[3,2,1,0];
alert(m);//输出3,2,1,0;这个值改变了,因为m只是aArr的一个引用,如果aArr的值改变了,那么m也会相应的改变。
</script>
请不要误导新人,你确信你测试过这段代码?你确定你理解引用的概念?
语气重了点,不好意思,我通常都这样,要么不写,要么充分验证才发布。
5 楼
kingwell.leng
2012-09-13
lazy_ 写道
lazy_ 写道
引用
<script>
var aArr = [0,1,2,3];
var m = aArr;
alert(m);//输出1,2,3
aArr=[3,2,1,0];
alert(m);//输出3,2,1,0;这个值改变了,因为m只是aArr的一个引用,如果aArr的值改变了,那么m也会相应的改变。
</script>
var aArr = [0,1,2,3];
var m = aArr;
alert(m);//输出1,2,3
aArr=[3,2,1,0];
alert(m);//输出3,2,1,0;这个值改变了,因为m只是aArr的一个引用,如果aArr的值改变了,那么m也会相应的改变。
</script>
请不要误导新人,你确信你测试过这段代码?你确定你理解引用的概念?
语气重了点,不好意思,我通常都这样,要么不写,要么充分验证才发布。
呵呵,有问题可以纠正。。。