资讯专栏INFORMATION COLUMN

20170606-浅拷贝与深拷贝

Kerr1Gan / 2685人阅读

摘要:什么是深拷贝,什么是浅拷贝中的浅拷贝与深拷贝是针对复杂数据类型引用类型的复制问题。

什么是深拷贝,什么是浅拷贝

JS中的浅拷贝与深拷贝是针对复杂数据类型(引用类型)的复制问题。

浅拷贝:浅拷贝是拷贝引用(拷贝地址),拷贝后两个变量指向的是同一块内存空间

深拷贝:会在内存中开辟一块新的内存空间,它不仅将原对象的各个属性逐个复制过去,而且将原对象各个属性所包含的内容也依次采用深复制的方法递归复制到新的内存空间中,并把新的内存空间的地址复制给第二个变量,这两个变量指向的是不同的对象,两个变量的任何操作都不会影响到对方

实现深拷贝的常用方法 1.JSON.parse(JSON.stringify(object)) 2. 递归实现深拷贝
function deepCopy(obj){
    if(typeof obj !== "object"){
        return obj
    }
    var temp = new Object()
    for(var i in obj){
        if(typeof obj[i] === "object"){
            temp[i] = arguments.callee(obj[i])
        }else {
            temp[i] = obj[i]
        }
    }
    return temp
}

这个方法能正确处理的对象只有 Number, String, Boolean, Array, 扁平对象,即那些能够被 json 直接表示的数据结构。

3. 通过jQuery的extend方法
var CopyObject = $.extend(true, {}, object)

源码分析

jQuery.extend = jQuery.fn.extend = function() {
    var src, copyIsArray, copy, name, options, clone,
        target = arguments[0] || {},
        i = 1,
        length = arguments.length,
        deep = false;

    // 如果第一个参数是布尔类型的,说明指定了是否要进行深拷贝,则第二个参数指的是目标对象
    if ( typeof target === "boolean" ) {
        deep = target;
        target = arguments[ i ] || {};
        i++;
    }

    // Handle case when target is a string or something (possible in deep copy)
    if ( typeof target !== "object" && !jQuery.isFunction(target) ) {
        target = {};
    }

    // extend jQuery itself if only one argument is passed
    if ( i === length ) {
        target = this;
        i--;
    }

    for ( ; i < length; i++ ) {
        // options为源对象
        if ( (options = arguments[ i ]) != null ) {
            
            for ( name in options ) {
                src = target[ name ];
                copy = options[ name ];

                // Prevent never-ending loop
                if ( target === copy ) {
                    continue;
                }

                // 处理纯对象和数组
                if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) {
                  
                    if ( copyIsArray ) {
                        // 被拷贝的对象是数组时
                        copyIsArray = false;
                        clone = src && jQuery.isArray(src) ? src : [];

                    } else {
                        // 被拷贝对象是对象
                        clone = src && jQuery.isPlainObject(src) ? src : {};
                    }

                    // 递归调用extend方法,实现该属性的深拷贝
                    target[ name ] = jQuery.extend( deep, clone, copy );

                
                } else if ( copy !== undefined ) {
                    // 如果属性是简单数据类型,直接复制
                    target[ name ] = copy;
                }
            }
        }
    }

    // Return the modified object
    return target;
};

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/83377.html

相关文章

  • 拷贝与深拷贝的区别

    摘要:浅拷贝与深拷贝一数据类型数据分为基本数据类型,和对象数据类型。浅拷贝是按位拷贝对象,它会创建一个新对象,这个对象有着原始对象属性值的一份精确拷贝。对于字符串数字及布尔值来说不是或者对象,会拷贝这些值到新的数组里。 浅拷贝与深拷贝 一、数据类型数据分为基本数据类型(String, Number, Boolean, Null, Undefined,Symbol)和对象数据类型。 基本数据类...

    jsyzchen 评论0 收藏0
  • JavaScript中的拷贝与深拷贝

    摘要:所以,深拷贝是对对象以及对象的所有子对象进行拷贝实现方式就是递归调用浅拷贝对于深拷贝的对象,改变源对象不会对得到的对象有影响。 为什么会有浅拷贝与深拷贝什么是浅拷贝与深拷贝如何实现浅拷贝与深拷贝好了,问题出来了,那么下面就让我们带着这几个问题去探究一下吧! 如果文章中有出现纰漏、错误之处,还请看到的小伙伴多多指教,先行谢过 以下↓ 数据类型在开始了解 浅拷贝 与 深拷贝 之前,让我们先...

    546669204 评论0 收藏0
  • JavaScript中的拷贝与深拷贝

    摘要:所以,深拷贝是对对象以及对象的所有子对象进行拷贝实现方式就是递归调用浅拷贝对于深拷贝的对象,改变源对象不会对得到的对象有影响。 上一篇 JavaScript中的继承 前言 文章开始之前,让我们先思考一下这几个问题: 为什么会有浅拷贝与深拷贝 什么是浅拷贝与深拷贝 如何实现浅拷贝与深拷贝 好了,问题出来了,那么下面就让我们带着这几个问题去探究一下吧! 如果文章中有出现纰漏、错误之处...

    AZmake 评论0 收藏0
  • 关于js的拷贝与深拷贝

    摘要:原文地址浅拷贝和深拷贝只针对像这样的复杂对象的简单来说,浅拷贝只拷贝一层对象的属性,而深拷贝则递归拷贝了所有层级。浅拷贝通过来实现浅拷贝。 原文地址:http://www.silenceboy.com/201... 浅拷贝和深拷贝只针对像Object, Array这样的复杂对象的.简单来说,浅拷贝只拷贝一层对象的属性,而深拷贝则递归拷贝了所有层级。 浅拷贝 通过 Object.ass...

    summerpxy 评论0 收藏0
  • Python拷贝与深拷贝

    摘要:浅拷贝与深拷贝上一篇文章文件夹处理下一篇文章与对比浅拷贝浅拷贝拷贝了引用,没有拷贝内容。实例的的结果的的深拷贝深拷贝对于一个对象所有层次的拷贝递归。 Python浅拷贝与深拷贝 上一篇文章:Python文件夹处理下一篇文章:Python==与is对比 1、浅拷贝 浅拷贝:拷贝了引用,没有拷贝内容。 实例: a=[1,2,3] b=a print(a的id:,id(a)) print...

    Yu_Huang 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<