问答

如何对对象进行自动监听, 且在克隆之后相应的更新属性?

作者:admin 2021-09-09 我要评论

有这么一个需求或需求, 给定一个对象, 其中一些属性是依赖其他属性的, 可以看做这些属性是"计算属性". 现在 浅拷贝 得到一个新对象, 拷贝的时候更新其中的一些属...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

有这么一个需求或需求, 给定一个对象, 其中一些属性是依赖其他属性的, 可以看做这些属性是"计算属性". 现在浅拷贝得到一个新对象, 拷贝的时候更新其中的一些属性, 希望在拷贝后得到的对象里面的计算属性也随之更新

描述可能比较抽象, 代码大致如下:

const o1 = {
  a: 1,
  get b() {
    return this.a + 1
  }
}

const o2 = {
  ...o1,
  a: 10
}

console.log(o2) // { a: 10, b: 2 }
// 然而我想要的结果是 { a: 10, b: 11 }

可以看到在拷贝之后属性 b 并没有随之更新(注意是拷贝之后形成的 o2, 我并不想直接修改 o1), 有没有方法在不手动修改 b 的情况下仅修改 a, b 自动监听 a 变化然后更新? 多谢

###

展开语法只会读取源对象上的value属性,并不会复制getters和setters。可以通过查看各自的属性描述符得出结论。

Object.getOwnPropertyDescriptor(o1, "b")
Object.getOwnPropertyDescriptor(o2, "b")  //o2对象并没有复制getter

可以通过Object.defineProperties

const o2 = {}
Object.defineProperties(o2,Object.getOwnPropertyDescriptors(o1));
o2.a = 10;
console.log(o2)

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 如何对对象进行自动监听, 且在克隆之后

    如何对对象进行自动监听, 且在克隆之后

  • Java String不可变特性研究发现的问题

    Java String不可变特性研究发现的问题

  • 原生js怎么控制checkbox切换祖先元素的

    原生js怎么控制checkbox切换祖先元素的

  • el-menu不同级别背景色不同怎么设置

    el-menu不同级别背景色不同怎么设置

腾讯云代理商
海外云服务器