IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

JavaScript深度克隆(深度拷贝)一个对象

WEB前端开发 2013-03-11 13:55:16 累计浏览 5,842 次
本机暂存

我有一个前端笔试题:使用JavaScript深度克隆一个对象。可是我发现大多数人都是空白,问他为什么不做,大部分说不懂这题目的意思。

科普一下:

js一般有两种不同数据类型的值:

基本类型(包括undefined,Null,boolean,String,Number),按值传递;

引用类型(包括数组,对象),按址传递,引用类型在值传递的时候是内存中的地址。例如:

1var a={"a":1};
2
3var b=a;
4
5b["b"]=2;
6
7console.log(a);//{"a":1,"b":2};

如果你修改b的值,那么a变量的值也发生了变化。

克隆或者拷贝分为2种:浅度克隆(拷贝),深度克隆(拷贝);

浅度克隆:基本类型为值传递,对象仍为引用传递。

深度克隆:所有元素或属性均完全克隆,并于原引用类型完全独立,即,在后面修改对象的属性的时候,原对象不会被修改。

我的深度克隆代码如下:

01function 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    }

主要使用了递归。
不过代码看上去挺变扭的,被朋友批了一顿,数组本来就是对象,可以精简代码。优化了一下,欢迎拍砖:

1function 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];

同分类推荐文章

  1. translateZ() (2026-06-25 21:18:56)
  2. translateY() (2026-06-25 21:17:56)
  3. translateX() (2026-06-25 21:16:01)

查看更多 前端 文章 →

建议继续学习

  1. JQuery实现Excel表格呈现 (累计阅读 48,346)
  2. 深入理解Javascript之执行上下文(Execution Context) (累计阅读 18,401)
  3. 从输入 URL 到页面加载完成的过程中都发生了什么事情? (累计阅读 15,931)
  4. 图片动态局部毛玻璃模糊效果的实现 (累计阅读 14,845)
  5. 天朝第二代身份证号码的验证机制 (累计阅读 14,760)
  6. HTML 5 的data-* 自定义属性 (累计阅读 14,348)
  7. 分享一个JQUERY颜色选择插件 (累计阅读 14,222)
  8. 什么是全栈工程师? (累计阅读 14,035)
  9. 快速排序(Quicksort)的Javascript实现 (累计阅读 11,733)
  10. 7 天打造前端性能监控系统 (累计阅读 11,187)