猿问

Mobx 的 observable 失去了子对象的平等性

当我从包含实际上是相同对象的字段的普通对象创建可观察对象时,此属性不再是相等的对象。所以如果我改变一个人的财产,第二个保持不变。


有没有正确的方法来处理这个问题?


import { observable } from "mobx";


const status = { id: "some-obj" };


const obj = {

  status,

  status2: status

};


const observableObj = observable(obj);


const isEqual = observableObj.status2 === observableObj.status;


document.body.innerHTML = `Is equal = ${isEqual}`;

console.log(observableObj);

https://codesandbox.io/s/mobx-equality-demo-5eowk


慕神8447489
浏览 94回答 1
1回答

桃花长相依

当您调用observable常规对象时,它不会改变它,而是创建新的可观察对象。MobX 在每个内部对象或值上递归地执行它,所以这就是为什么observableObj.status2和observableObj.status不相等的原因。它们是从同一个“蓝图”对象创建的,但每个都是独立的副本,如果我可以这样说的话。原来status还是regular object,status2里面变成了observable object observableObj。希望这是有道理的。您可以做的就是在status将其传递给内部之前使其自身可观察到obj,如下所示:const status = observable({ id: "some-obj" });const obj = {  status,  status2: status};const observableObj = observable(obj);observableObj.status2 === observableObj.status // => true这样 Mobx 就不会对它做任何事情,因为它已经是一个observable.代码沙盒:https://codesandbox.io/s/httpsstackoverflowcomquestions64032286-rxj5m ?file=/index.js
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答