JavaScript中的对象复制(Object Clone)

JavaScript中并没有直接提供对象复制(Object Clone)的方法。因此下面的代码中改变对象b的时候,也就改变了对象a。

a = {k1:1, k2:2, k3:3};
b = a;
b.k2 = 4;

如果只想改变b而保持a不变,就需要对对象a进行复制。

用jQuery进行对象复制

在可以使用jQuery的情况下,jQuery自带的extend方法可以用来实现对象的复制。

a = {k1:1, k2:2, k3:3};
b = {};
$.extend(b,a);
        var obj1 = {
		apple: 0,
		banana: {weight: 52, price: 100},
		cherry: 97
	};
	var obj3;
	obj3 = $.extend(true, obj1, obj3);
	console.log(obj1 === obj3);//true
	obj3.apple = 3;
	console.log(obj1 === obj3);//true
	obj3 = $.extend(true, {}, obj1);
	console.log(obj1 === obj3);//false

Keep in mind that the target object (first argument) will be modified, and will also be returned from $.extend(). If, however, you want to preserve both of the original objects, you can do so by passing an empty object as the target:

1

var object = $.extend({}, object1, object2);

方法对象不需要复制也不会存在引用的问题

if(requestObj.error){
		errorCallback = requestObj.error;
	}
	
//	console.log(requestObj.error === errorCallback);//true
	requestObj.error = function(req, msg, err){
		console.log(requestObj.url);
		console.log(req);
		console.log(msg);
		console.log(err);
		if(errorCallback){
//			console.log(requestObj.error === errorCallback);//false
			errorCallback(req, msg, err);
		}
		
		if(dialogConfirm.dialog( "isOpen" )){
			dialogConfirm.dialog('close');
		}
		$('#confirmMsg').text(err);
		$('.confirm-buttons').hide();
		$('#btnOk').show();
		dialogConfirm.dialog('open');
		$('#btnOk').unbind('click');
		$('#btnOk').on('click', function() {
			dialogConfirm.dialog('close');
			return false;
		});
	}
//	console.log(requestObj.error === errorCallback);//false

自定义clone()方法来实现对象复制

下面的方法,是对象复制的基本想法。

Object.prototype.clone = function() {
  var copy = (this instanceof Array) ? [] : {};
  for (attr in this) {
    if (!obj.hasOwnProperty(attr)) continue;
    copy[attr] = (typeof this[i] == "object")?obj[attr].clone():obj[attr];
  } 
  return copy;
};


a = {k1:1, k2:2, k3:3};
b = a.clone();

下面的例子则考虑的更全面些,适用于大部分对象的深度复制(Deep Copy)。

function clone(obj) {
    // Handle the 3 simple types, and null or undefined
    if (null == obj || "object" != typeof obj) return obj;

    // Handle Date
    if (obj instanceof Date) {
        var copy = new Date();
        copy.setTime(obj.getTime());
        return copy;
    }

    // Handle Array
    if (obj instanceof Array) {
        var copy = [];
        for (var i = 0, var len = obj.length; i < len; ++i) {
            copy[i] = clone(obj[i]);
        }
        return copy;
    }

    // Handle Object
    if (obj instanceof Object) {
        var copy = {};
        for (var attr in obj) {
            if (obj.hasOwnProperty(attr)) copy[attr] = clone(obj[attr]);
        }
        return copy;
    }

    throw new Error("Unable to copy obj! Its type isn't supported.");
}

猜你喜欢

转载自blog.csdn.net/liduanwh/article/details/82800657