Object.assign属性拷贝

发布于 2022-09-07 21:16:47 字数 328 浏览 21 评论 0

var obj = {
  name: 'obj',
  fn: {
    add: true,
    edit: true
  }
}

var page1 = {
  name: 'page1',
  fn: {
    edit: false
  }
}

var config = Object.assign({}, obj, page1)
// {name: 'page1', fn: {edit: false}}

请问下我如何才能只覆盖edit一个值呢?
达到最终这个结果
{name: 'page1', fn: {add:true, edit: false}}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

负佳期 2022-09-14 21:16:47
let result = {};
Object.keys(obj).forEach(key => {
    let assign = obj[key];
    if (page1.hasOwnProperty(key)) {
        if (typeof page1[key] === "object") {
            if(page1[key] instanceof Array) {
                assign = obj[key].concat(page1[key]);
            } else {
                assign = {...obj[key], ...page1[key]};
            }
        } else {
            assign = page1[key];
        }
    }
    result[key] = assign;
});

其它类型的自己实现一下吧。
或者你可以使用lodash

舟遥客 2022-09-14 21:16:47

如果这样的属性有很多,建议深拷贝

如果只有这一个,建议这么写:

var obj = {
  name: 'obj',
  fn: {
    add: true,
    edit: true
  }
}

var page1 = {
  name: 'page1',
  fn: {
    edit: false
  }
}

var config = Object.assign({}, obj)
config.fn.edit = page1.fn.edit;
// {name: 'page1', fn: {add: true, edit: false}}
标点 2022-09-14 21:16:47
var obj = {
  name: 'obj',
  fn: {
    add: true,
    edit: true
  }
}
var page1 = {
  name: 'page1',
  fn: {
    edit: false
  }
}
Object.assign(obj.fn,page1.fn);

Objct.assign

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文