JavaScript深度克隆(深度拷贝)一个对象
来源:互联网 发布:python 提取文件内容 编辑:程序博客网 时间:2024/05/13 01:07
纯属理论阶段
有一个前端笔试题:使用JavaScript深度克隆一个对象。可是我发现大多数人都是空白,问他为什么不做,大部分说不懂这题目的意思。
科普一下:
js一般有两种不同数据类型的值:
基本类型(包括undefined,Null,boolean,String,Number),按值传递;
引用类型(包括数组,对象),按址传递,引用类型在值传递的时候是内存中的地址。例如:
1
var
a={
"a"
:1};
2
3
var
b=a;
4
5
b[
"b"
]=2;
6
7
console.log(a);
//{"a":1,"b":2};
如果你修改b的值,那么a变量的值也发生了变化。
克隆或者拷贝分为2种:浅度克隆(拷贝),深度克隆(拷贝);
浅度克隆:基本类型为值传递,对象仍为引用传递。
深度克隆:所有元素或属性均完全克隆,并于原引用类型完全独立,即,在后面修改对象的属性的时候,原对象不会被修改。
我的深度克隆代码如下:
01
function
cloneObject(o) {
02
if
(!o ||
'object'
!==
typeof
o) {
03
return
o;
04
}
05
var
temp;
06
if
(o.constructor === Array){
07
//temp=o.concat();
08
temp = [];
09
var
i = o.length;
10
while
(i--) {
11
temp[i] = cloneObject(o[i]);
12
}
13
}
else
if
(o.constructor === Object){
14
temp = {};
15
for
(
var
k
in
o) {
16
if
(o.hasOwnProperty(k)){
17
temp[k] = cloneObject(o[k]);
18
}
19
}
20
}
21
return
temp;
22
}
主要使用了递归。
不过代码看上去挺变扭的,被朋友批了一顿,数组本来就是对象,可以精简代码。优化了一下,欢迎拍砖:
1
function
cloneObject(obj){
2
var
o = obj.constructor === Array ? [] : {};
3
for
(
var
i
in
obj){
4
if
(obj.hasOwnProperty(i)){
5
o[i] =
typeof
obj[i] ===
"object"
? cloneObject(obj[i]) : obj[i];
0 0
- JavaScript深度克隆(深度拷贝)一个对象
- JavaScript深度克隆(深度拷贝)一个对象
- JavaScript深度克隆(深度拷贝)一个对象
- javascript 深度克隆(深度拷贝一个对象) prototype __ptoto__ consstructor
- javascript深度克隆一个对象
- javascript深度克隆一个对象
- JavaScript对象深度克隆
- javascript 深度拷贝对象
- JavaScript 深度克隆 JSON 对象
- JavaScript的对象深度克隆
- Java深度拷贝一个对象
- javascript中对象的深度克隆
- JavaScript中对象的深度克隆
- javascript中对象的深度克隆
- javascript中对象的深度克隆
- JavaScript的对象深度克隆方法
- javaScript中对象的深度克隆
- javascript中对象的深度克隆
- Cocos2d-x中自定义粒子系统
- Spring 之 Container Extension points
- 数据结构 第一章 绪论 思维导图
- google codejam 汇总
- 字节顺序转换函数
- JavaScript深度克隆(深度拷贝)一个对象
- ffmpeg源码分析之媒体打开过程
- 精确的数值计算BigDecimal
- 转:Android 开源框架Universal-Image-Loader完全解析(二)--- 图片缓存策略详解
- Android的全局键(home键/长按耳机键)详解【android源码解析八】
- xp ie 8 mvc 下载 文件 问题
- HDOJ 5012 Dice--2014网络赛西安赛区F题
- Cocos2d-X Scrollview与CCMenu的结合使用在屏幕滑动实例
- 转:Android 开源框架Universal-Image-Loader完全解析(三)---源代码解读