解构嵌套对象,但保留对嵌套对象的引用

Destructure a nested object, but keep a reference to the nested object

我有一个简单的用例,但我认为使用 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;

...但这似乎有点笨拙,不是吗?有没有我遗漏的东西,或者这只是语法中的 "gap"?

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

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);

这取决于您是否希望嵌套对象也包含解构的属性。

如果你这样做,那么请参阅

如果不这样做,则使用 ...rest 语法,如下所示:

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