首页 > 解决方案 > 解构嵌套对象,但保留对嵌套对象的引用

问题描述

我有一个简单的用例,但我认为 ES6 语法是不可能的。我想使用对象解构从嵌套对象中检索某些已知属性,但我还想要对该嵌套对象的引用,以便我可以将它传递给可能关心其他属性的其他函数。

这是一个示例对象:

var record = {
    name: "foo",
    metadata: {
        createdDate: "2017-02-19",
        lastModifiedDate: "2018-07-24",
        type: "bar"
    }
};

在我的代码中的某个时刻,我想从元数据中提取一些值。同时,我还想提取整个元数据对象:

let {
    metadata: {
        createdDate
    }
} = record;

if ( date( createdDate ).before( NEW_FEATURE_DATE ) ){
    oldFeature( metadata );
} else {
    newFeature( metadata );
}

不幸的是,我对该metadata属性的引用纯粹用于解构......它的价值是undefined(从技术上讲,未定义,它没有价值)。

我知道我可以用类似的东西解决这个问题

let {
        metadata: {
            createdDate
        }
    } = record,
    metadata = record.metadata;

或者

let {
        metadata
    } = record,
    {
        createdDate
    } = metadata;

……但这似乎有点笨拙,不是吗?是否有我遗漏的东西,或者这只是语法中的“差距”?

标签: javascriptdestructuring

解决方案


您可以添加另一个相同的属性而无需解构。

var record = { name: "foo", metadata: { createdDate: "2017-02-19",  lastModifiedDate: "2018-07-24", type: "bar" } };

let { metadata: { createdDate }, metadata } = record;
//    ^^^^^^^^                                        for nested destructuring
//                               ^^^^^^^^             for the value

console.log(metadata);
console.log(createdDate);


推荐阅读