首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将mobx反应形式与mobx状态树存储绑定

如何将mobx反应形式与mobx状态树存储绑定
EN

Stack Overflow用户
提问于 2018-12-01 14:27:30
回答 1查看 1.1K关注 0票数 2

我有一个包含三个字段A、B和C的表单,我使用莫布克斯反应形式来处理这些字段,因为它附带了onChange更新和验证。我已经设置好了,当我注销这些值时,它会正常工作。

代码语言:javascript
复制
const View = inject('store')(observer(({ title }: Props) => {
  return (
    <div>
      <form onSubmit={form.onSubmit}>
        <label htmlFor={form.$('A').id}>
          {form.$('A').label}
        </label>
        <input {...form.$('A').bind()} />

        <label htmlFor={form.$('B').id}>
          {form.$('B').label}
        </label>
        <input {...form.$('B').bind()} />

        <label htmlFor={form.$('C').id}>
          {form.$('C').label}
        </label>
        <input {...form.$('C').bind()} />

        <button type="submit" onClick={form.onSubmit}>
          Submit
       </button>
      </form>
    </div>
  );
}));

我将使用来自字段A、B和C的值来计算将出现在应用程序中的附加值D和E。

对于状态管理,我使用mobx状态树创建存储。

代码语言:javascript
复制
export const Store = types.model('Store', 
{
  A: types.maybeNull(types.number),
  B: types.maybeNull(types.number),
  C: types.maybeNull(types.number),
  D: types.maybeNull(types.number),
  E: types.maybeNull(types.number),
})
  .views(self => {
    return { 
      getD: () => self.D,
      getE: () => self.E 
    };
  })
  .actions(self => {
    return {
      setD: (A, B) => self.D = A + B,
      setE: (B, C) => self.E = C - B,
      resetStore: () => {
        self.A = defaultState.A;
        self.B = defaultState.B;
        self.C = defaultState.C;
        self.D = defaultState.D;
        self.E = defaultState.E;
      },
    };
  });

如何将mobx-react-form字段A、B和C绑定到存储中的相应值,以便它们在更改时更新?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-12-01 15:06:51

井,

首先,我希望你注意到,你试图连接两个不同的州经理。

我非常喜欢mobx-recat格式!但是你应该考虑它自动地管理你的状态。

您可以将自己绑定到onChange,并相应地更新D、E。

例如:

代码语言:javascript
复制
<input onChange={e => {
   form.$('B').set(e.target.value);
   // handle D,E according to value
}} />

这是最“直接”的处理方法。如果你想用更多的"mobx“方式来解决这个问题,

做一些像这样的事情:

代码语言:javascript
复制
form.$('B')
   .observe(({ form, field, change }) => { 
     // deal with D,E according to values
   });

要了解更多信息,我将查看:https://foxhound87.github.io/mobx-react-form/docs/extra/mobx-events.html

我建议继续使用这个库(mobx-react form )来控制表单,并使用直接挂钩(第一个例子),或者通过观察表单传播到其他商店中其他值的变化。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53571748

复制
相关文章

相似问题

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