首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从mobx存储更新输入值

从mobx存储更新输入值
EN

Stack Overflow用户
提问于 2022-06-01 09:08:40
回答 1查看 172关注 0票数 0

我有一个MobX存储和两个组件,连接到相同的值:

代码语言:javascript
复制
import { makeAutoObservable } from 'mobx';
import { observer } from 'mobx-react-lite';

const store = makeAutoObservable({
  value: 0,
  setValue: (v) => {
    this.value = v;
  },
});

const ComponentOne = observer(() => {
  function handleOnChange(e) {
    store.setValue(e.target.value);
  }

  return <input value={store.value} onChange={handleOnChange} />;
});

const ComponentTwo = observer(() => {
  function handleOnChange(e) {
    store.setValue(e.target.value);
  }

  return <input value={store.value} onChange={handleOnChange} />;
});

我需要:

更改debounce.的输入值

  1. 应使<ComponentTwo/>中的输入值从新的存储值
  2. 更新为从组件存储到MobX存储的<ComponentOne/>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-06-01 18:15:27

我的解决方案:

代码语言:javascript
复制
import { makeAutoObservable } from 'mobx';
import { observer } from 'mobx-react-lite';
import { useDebouncedCallback } from 'use-debounce';

const store = makeAutoObservable({
  value: 0,
  setValue: (v) => {
    this.value = v;
  },
});

export function useStoreValue() {
  const storeValue = store.value;
  const setStoreValue = store.setValue;
  const [value, setValue] = useState(storeValue);

  // eslint-disable-next-line object-curly-newline
  const debouncedSetStoreValue = useDebouncedCallback(setStoreValue, 350, { maxWait: 1000 });

  useEffect(
    () => {
      if (storeValue !== value) {
        debouncedSetStoreValue(value);
      }
    },
    // eslint-disable-next-line react-hooks/exhaustive-deps
    [value]
  );

  useEffect(() => {
    setValue(storeValue);
  }, [storeValue]);

  return [value, setValue];
}

const ComponentOne = observer(() => {
  const [value, setValue] = useStoreValue();

  function handleOnChange(e) {
    setValue(e.target.value);
  }

  return <input value={value} onChange={handleOnChange} />;
});

const ComponentTwo = observer(() => {
  const [value, setValue] = useStoreValue();

  function handleOnChange(e) {
    setValue(e.target.value);
  }

  return <input value={value} onChange={handleOnChange} />;
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72459203

复制
相关文章

相似问题

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