Javascript:如何复制对象并保持其原型链

Javascript: how to copy a object and keep its prototype chain?

本文关键字:原型 对象 何复制 复制 Javascript      更新时间:2023-09-26

我有一个对象:

var obj = {
     name: "Mike"
}
// and its prototype property:
obj.__proto__:
   say: function () {...}
   walk: function () {...}

我想复制它并保留__proto__

首先我想到了jQuery $.extend方法:

$.extend({}, obj)

但返回的是像一样合并__proto__

{
    name: "Lee",
    say: function () {},
    walk: function () {}
}

那么我如何在保持原型链的情况下复制对象呢?

首先,您想要什么样的副本?深度复制还是浅层复制?假设您想要浅拷贝;只需将src自己的属性(除非dest已经具有相同的属性)和__proto__复制到dest

function copy(dest, src) {
    var p;
    for (p in src) {
        if (src.hasOwnProperty(p) && !dest.hasOwnProperty(p)) {
            dest[p] = src[p];
        }
    }
    dest.__proto__ = src.__proto__;
}

Fiddle:http://jsfiddle.net/U6uY4

如果您想要深度复制,请将for .. in循环替换为适合您的用例的深度复制算法。


请注意,这是不常见的要求。我建议你再想想你真正想做什么。