【问题标题】:how to catch a reference loop in a javascript object?如何在 javascript 对象中捕获引用循环?
【发布时间】:2021-01-20 17:48:39
【问题描述】:

编辑:这被标记为深度克隆问题的副本,但我的问题(参见标题和最后一个短语)是关于判断对象是否引用自身的方法,深度克隆部分仅用于提供上下文

我正在尝试实现一个函数,它可以让我在不覆盖嵌套字段的情况下深度复制嵌套对象(我知道 lodash 可以解决这个问题,但我宁愿不使用它)。

这是我写的:

function copyObject(target, source) {
    if (typeof target !== "object" || !target) {
        throw 'target nust be a non-null javascript object';
    }
    Object.entries(source).map(([key, value]) => {
        if (typeof value === "object"
                && typeof target[key] === "object"
                && target[key] !== null) {
            copyObject(target[key], value);
        } else {
            target[key] = value;
        }
    })
    return target;
}

问题是如果它的源参数是一个像这样引用自己的对象,这个函数会进入一个无限循环(因为它总是会在源的 c 属性上调用自己):

let src = {
    a: "a",
    b: "b",
}
src.c = src;

有没有办法知道引用是否是对象的一部分?我认为在 C 中这可以通过查看内存地址来实现,但在 JS 中我不知道。

【问题讨论】:

标签: javascript deep-copy


【解决方案1】:

如果我正确理解了这个问题,您最好在 .map 函数的开头使用下面的代码。

if( Object.is(value, source) ) { 返回 }

MDN 参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is

Object.is() 判断两个值是否相同。如果满足以下条件之一,则两个值相同...

  • 都是同一个对象(意味着两个值都引用内存中的同一个对象)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-01-10
    • 2015-03-17
    • 2018-01-19
    • 1970-01-01
    相关资源
    最近更新 更多