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

其他教程   发布日期:2023年08月19日   浏览次数:533

本篇内容主要讲解“Antd中Form表单的onChange事件中执行setFieldsValue不生效怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Antd中Form表单的onChange事件中执行setFieldsValue不生效怎么解决”吧!

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

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

    原因是因为

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

    解决方案

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

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

    1. <FormItem label="路由节点" {...nodelayout}>
    2. {getFieldDecorator(`node`, {
    3. rules: [
    4. {
    5. required: true,
    6. message: '选择要指定的路由节点',
    7. }],
    8. getValueFromEvent: (val: any) => {
    9. let nodesArr = [] as any;
    10. for (let item of transferList) {
    11. for (let j of val) {
    12. if ((item as any).id === j) {
    13. nodesArr.push(item);
    14. }
    15. }
    16. }
    17. return nodesArr;
    18. }
    19. })(
    20. <Transfer
    21. operations={['>>', '<<']}
    22. dataSource={transferList}
    23. filterOption={(inputValue: any, option: any) =>
    24. option.value.indexOf(inputValue) > -1
    25. }
    26. showSearch
    27. lazy={false}
    28. targetKeys={targetKeys}
    29. onChange={transferHandleChange}
    30. onSearch={transferHandleSearch}
    31. render={item => item.value}
    32. />,
    33. )}
    34. </FormItem>

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

    antd Design Form setFieldsValue的使用

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

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

    1. componentDidMount() {
    2. gainCountry().then(res => {
    3. // 这里进行数据请求
    4. ......
    5. })
    6. }

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

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

    解决

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

    1. class Index extends Component{
    2. constructor(props) {
    3. super(props)
    4. this.state = { }
    5. }
    6. // 创建一个ref
    7. formRef = React.createRef()
    8. render(){
    9. return{
    10. {/* 绑定到Form身上*/}
    11. <Form ref={this.formRef}>
    12. <Form.Item name="example">
    13. <Input />
    14. </Form.Item>
    15. </Form>
    16. }
    17. }
    18. }
    19. export default BaseInfo

    在需要的地方进行使用:

    1. // example 为Form.Item中的name
    2. this.formRef.current.setFieldsValue({
    3. example: ‘从后台返回要显示的值',
    4. })

    以上就是Antd中Form表单的onChange事件中执行setFieldsValue不生效怎么解决的详细内容,更多关于Antd中Form表单的onChange事件中执行setFieldsValue不生效怎么解决的资料请关注九品源码其它相关文章!