验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

Antd中Form表单的onChange事件中执行setFieldsValue不生效怎么解决

阅读:560 来源:乙速云 作者:代码code

Antd中Form表单的onChange事件中执行setFieldsValue不生效怎么解决

      Antd中Form表单的onChange事件中执行setFieldsValue不生效

      如果在Form表单中onChange事件中,手写了一个setFieldsValue, 则不会生效。

      原因是因为

      Form表单会在手写的onChange事件之后执行内部的setFieldsValue,所以会将我们之前手写的setFieldsValue给覆盖掉。

      解决方案

      1. 使用setTimeout延时。此方案不推荐

      2. 使用getValueFromEvent. 是当onChange的时候,更改form表单的值的情景下使用

      
           {getFieldDecorator(`node`, {
              rules: [
                 {
                    required: true,
                    message: '选择要指定的路由节点',
                  }],
              getValueFromEvent: (val: any) => {
                  let nodesArr = [] as any;
                   for (let item of transferList) {
                       for (let j of val) {
                          if ((item as any).id === j) {
                            nodesArr.push(item);
                          }
                        }
                   }
                   return nodesArr;
              }
           })(
          >', '<<']}
             dataSource={transferList}
             filterOption={(inputValue: any, option: any) =>
                option.value.indexOf(inputValue) > -1
             }
             showSearch
             lazy={false}
             targetKeys={targetKeys}
             onChange={transferHandleChange}
             onSearch={transferHandleSearch}
             render={item => item.value}
          />,
      )}
      

      3. 如果你只想简单的更改表单的值setFieldsValue,而不是在onChange的时候触发。那么可以使用normalize. 与上述的getValueFromEvent类似,都是option的一个属性。

      antd Design Form setFieldsValue的使用

      最近项目使用的是antd Design 4.x 版本,碰到个需要加载后端数据并展示,并且用户可以进行修改的需求,前端采用的是antd的Form表单来实现

      组件加载的时候向后端请求数据

      componentDidMount() {
              gainCountry().then(res => {
                  // 这里进行数据请求
                  ......
              })
          }

      form表单要回填数据一般会想到的是initialValues,但是这是适用于初始化值的时候,官方文档的原话:“initialValues 不能被 setState 动态更新,你需要用 setFieldsValue 来更新”。

      搜索一番setFieldsValue的使用,基本上都是:this.props.form.setFieldsValue, props自带form,试用之后发现报错,this.props下没有form,这个好像只适用于antd 3.x

      解决

      antd4.x 中使用setFieldsValue 是通过ref来进行操作,如下所示:

      class Index extends Component{
          constructor(props) {
              super(props)
              this.state = { }
          }
          // 创建一个ref
          formRef = React.createRef()
          render(){
              return{
                   {/* 绑定到Form身上*/}
                   
                      
                         
                      
                   
              }
          }
      }
      export default BaseInfo

      在需要的地方进行使用:

      // example 为Form.Item中的name
      this.formRef.current.setFieldsValue({
             example: ‘从后台返回要显示的值',
                      
      })
    分享到:
    *特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
    相关文章
    {{ v.title }}
    {{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
    你可能感兴趣
    推荐阅读 更多>