我有一个MobX存储和两个组件,连接到相同的值:
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.的输入值
<ComponentTwo/>中的输入值从新的存储值<ComponentOne/>。发布于 2022-06-01 18:15:27
我的解决方案:
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} />;
});https://stackoverflow.com/questions/72459203
复制相似问题