浅谈Javascript 中几种克隆(clone)方式
2015-08-14 20:01
671 查看
clone就是把原来的东西原样复制一份,新复制的东西和以前的东西没有任何关系
一:在Javascript里,如果克隆对象是基本类型,我们直接赋值就可以了:
把一个值赋给另一个变量时,当那个变量的值改变的时候,另一个值不会受到影响。
这里需要注意的是,复制会把A对象的值复制一份给B,由于是基本类型,这个值不再指向其他地方,所以当A的值发生改变时,B的值不会改变,但是如果赋值的是对象的话,情况就不同了,虽然也是把A的值复制给B,但是这个值指向堆内存,堆内存里存储的才是真正的内容,所以当A对象来改变这个内容的时候,B指向的内容也就发生了变化
二:如果不是基本类型,那就有所有不同了:
如果我们想克隆一个数组,最简单的办法:
我们可以创建一个函数来克隆所有对象:
三:节点克隆:
一:在Javascript里,如果克隆对象是基本类型,我们直接赋值就可以了:
var sStr = "kingwell"; var cStr = sStr; alert(cStr);//输出kingwell sStr = "abc"; alert(cStr);//输出kingwell;
把一个值赋给另一个变量时,当那个变量的值改变的时候,另一个值不会受到影响。
这里需要注意的是,复制会把A对象的值复制一份给B,由于是基本类型,这个值不再指向其他地方,所以当A的值发生改变时,B的值不会改变,但是如果赋值的是对象的话,情况就不同了,虽然也是把A的值复制给B,但是这个值指向堆内存,堆内存里存储的才是真正的内容,所以当A对象来改变这个内容的时候,B指向的内容也就发生了变化
二:如果不是基本类型,那就有所有不同了:
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节点,深度克隆,克隆节点以及节点下面的子内容。
相关文章推荐
- JS 总结
- js易错总结
- Knockout.js on the way
- js中的"=="和equals()以及is()三者的区别
- ASP.NET MVC 中使用JavaScriptResult
- js判断对象的类型
- js的闭包
- 【JavaScript】BOM总结
- JavaScript之Window对象
- 解决跨域访问(服务器端、Js端)
- JavaScript中一些常用API使用方法简析
- JavaScript——概述
- Javascript面向对象之继承
- 如何在JavaScript各种各样的上下文中确定this指的是什么?
- Javascript 面向对象编程(一):封装
- Ext.form.FileUploadField第二次选择同一附件无效的问题
- 使用weibo4j中JSON入门
- js data日期初始化的5种方法
- javascript -- 绘制箭头
- (转)JS的parent对象