首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不使用useLocalObservable的观察者

不使用useLocalObservable的观察者
EN

Stack Overflow用户
提问于 2022-03-24 08:11:03
回答 1查看 456关注 0票数 1
代码语言:javascript
复制
import { Observer, useLocalObservable } from 'mobx-react-lite';

function App() {
  const { count, decrement, increment } = useLocalObservable(() => ({
    count: 0,
    increment() { this.count++ },
    decrement() { this.count-- },
  }));

  return (
    <div>
      <Observer>{() => (<div>{count}</div>)}</Observer>
      <button onClick={() => { decrement() }} >decrement</button>
      <button onClick={() => { increment() }} >increment</button>
    </div>
  );
}

观察者不使用useLocalObservable.when我点击按钮什么都没有更新。原因是什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-24 10:21:06

Observer跟踪其内部所有可观察到的数据,并在该可观测数据发生变化时重新呈现。当您从可观察到的count外部取消引用Observer时,从那时起,它只是一个常规的JavaScript数,因此Observer没有什么可跟踪的。

相反,您可以在Observer中取消它的引用,它将工作:

代码语言:javascript
复制
import { Observer, useLocalObservable } from 'mobx-react-lite';

function App() {
  const state = useLocalObservable(() => ({
    count: 0,
    increment() { state.count++ },
    decrement() { state.count-- },
  }));

  return (
    <div>
      <Observer>{() => <div>{state.count}</div>}</Observer>
      <button onClick={state.decrement}>decrement</button>
      <button onClick={state.increment}>increment</button>
    </div>
  );
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71598936

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档