记录antd form组件使用中的几个小功能

一、表单提交

表单提交的时候使用form.validateFields((err,values)=>{}),如果errfalse则所有都通过了表单校验,values是定义表单项时的对应名称和值的对象。

//添加数据的确定按钮
function onOk(){
  const {form} = formRef.current.props;
  form.validateFields((err,values)=>{
    console.log(values,'values')
    if(err) return false;
    
  });
}

如果我们的表单中出现滚动条,在点击提交的时候需要将未通过校验的的表单项移动到视图中,可以使用validateFieldsAndScroll:

//添加数据的确定按钮
function onOk(){
  const {form} = formRef.current.props;
  form.validateFieldsAndScroll((err,values)=>{
      console.log(values,'values')
      if(err) return false;
  })
}

效果如图:

如上图填完可视区域后 ,直接点击确定,那么视图会滚动到未填写的form项上。

 

二、重置表单

    //点击重置
    onReset(){
        //这里是重置表单中每一项的数据
        this.props.form.resetFields();
        
        //如果只想重置某一项则传入一个数组即可,如下只重置loginname,和loginpass项的数据
        //this.props.form.resetFields(['loginname','loginpass']);
    }

三、设置表单项的初始默认值

这个默认值在用户改变后当点击重置按钮时恢复初始值initialValue

<Form.Item label="用户状态">
    {getFieldDecorator('userstatus',{
        rules:[{required:true,message:'必选'}],
        initialValue:'1'
    })(
        <Select>
            <Option value="1">正常</Option>
            <Option value="2">锁定</Option>
        </Select>
    )}
</Form.Item>
<Form.Item label="用户级别">
    {getFieldDecorator('userlevel',{
        rules:[{required:true,message:'请输入用户级别'}],
        initialValue:50
    })(
        <InputNumber  style={{width:'100%'}} min={1} max={100}  />
    )}
</Form.Item>

四、改变某一项表单项的值

通过使用setFieldsValue方法进行更新表单的某一项值,传入一个对象,对象的key必须是表单项里面已经存在的。这里通常用在修改数据的时候,填充表单项该数据的各个信息。

constructor(props){
    super(props);
    this.onReset = this.onReset.bind(this);
    this.initFieldsValue={
        'userlevel':30,
        'userstatus':'1'
    }
}
componentDidMount(){
    this.props.form.setFieldsValue(this.initFieldsValue);
}

 

五、多个验证规则时使用validateFirst:true

validateFirst:当某一规则校验不通过时,是否停止剩下的规则的校验

例如我们校验确认密码时有三个规则:

  • 密码至少由8位包含字母、数字、特殊字符两种组合
  • 不得超过20位
  • 两次密码输入是否一致

如果不设置validateFirst:true那么这三个规则都不符合时会同时出现所有的错位信息,也会导致布局挤开需要的空间如:

加上以后,第一条校验不通过就会停止校验解决上面的问题,也可以让用户逐步解决问题:

这个时候还需要调整你的校验顺序,自己决定那一条优先校验,如上面这里其实应该优先校验密码是否一致。

代码调整校验顺序顺序后:

<Form.Item label="确认密码">
    {getFieldDecorator('cfmloginpass', {
        rules: [{ required: true, message: '请输入密码' },
            {validator:(rules,value,callback)=>                 
                {this.handleCfmPwd(rules,value,callback)}},
            {max:20,message:'不得超过20位'},
            pattern('pwd')
        ],
        validateFirst:true
    })(<Input autoComplete="off" />)}
</Form.Item>

 

 

与之相关的:

antd form使用pattern和validator自定义校验规则

antd自定义校验规则校验两次密码是否一致

 

 

 

 

 

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在ant Design,我们可以使用Form组件Form.Item组件来创建表单,动态增减表单项可以通过state来控制表单项的数量,然后根据state的值来渲染对应数量的表单项。 首先,我们需要设置一个state来保存表单项的数量,可以使用数组来保存每个表单项的值,例如: ```javascript state = { formItems: [{ id: 1, value: '' }] }; ``` 然后,我们可以通过map函数来遍历表单项的数组,动态生成对应数量的表单项: ```javascript const { formItems } = this.state; {formItems.map(item => ( <Form.Item key={item.id}> {getFieldDecorator(`item-${item.id}`, { initialValue: item.value })(<Input />)} </Form.Item> ))} ``` 当需要增加或减少表单项的数量时,我们可以通过点击按钮来触发对应的函数,例如增加表单项的函数可以这样实现: ```javascript addFormItem = () => { const { formItems } = this.state; const newFormItem = { id: formItems.length + 1, value: '' }; this.setState({ formItems: [...formItems, newFormItem] }); } ``` 删除表单项的函数可以这样实现: ```javascript removeFormItem = (id) => { const { formItems } = this.state; const newFormItems = formItems.filter(item => item.id !== id); this.setState({ formItems: newFormItems }); } ``` 在表单提交时,我们可以通过getFieldsValue函数获取到表单的值并进行提交操作: ```javascript handleSubmit = (e) => { e.preventDefault(); const { form, formItems } = this.props; form.validateFields((err, values) => { if (!err) { const formValues = Object.keys(values).reduce((result, key) => { const id = parseInt(key.split('-')[1]); const value = values[key]; const formItem = formItems.find(item => item.id === id); result.push({ id, value }); return result; }, []); console.log(formValues); // 进行提交操作 } }); } ``` 以上就是使用antd实现动态增减表单项并设置表单回显的方法,通过动态管理state的表单项数组来动态渲染、增减表单项,通过getFieldsValue函数获取表单的值并进行提交操作。 ### 回答2: Antd 是一款基于 React 的 UI 组件库,它提供了一系列易于使用和美观的表单组件。在使用 Antd 动态增减表单项时,我们可以很容易地实现表单项的设置和回显。 首先,我们可以使用 AntdForm 组件来创建表单项。在表单项的设置方面,我们可以通过调用 Form 的 getFieldDecorator 方法来设置表单项的初始值、校验规则和事件处理函数等。 接着,当需要动态增减表单项时,我们可以利用 Antd 的 Button 组件来触发增减操作。通过在点击事件操作表单项数据(如数组的 push、splice 等方法),我们可以动态地添加或删除表单项。 对于表单项的回显,我们可以在表单项初始化时将表单值设置为从后端获取的数据。这样,当我们动态增减表单项后,原有的表单项会自动填充之前的值。这个过程可以通过在 Form 组件的 initialValue 属性设置从后端获取的数据来实现。 当用户提交表单时,我们可以通过调用 Antd 提供的 Form 的方法(如 validateFieldsAndScroll)来验证并获取表单数据。然后,我们可以将表单数据提交到后端进行处理。 总结起来,通过使用 Antd 提供的 Form 组件结合动态增减表单项的操作,我们可以很方便地设置和回显表单项。同时,借助 Antd 的其他组件和方法,我们还能够实现表单项的校验、事件处理和提交等功能Antd 提供了一整套完善的表单解决方案,可供我们在各种场景灵活使用。 ### 回答3: antd是一个非常流行的React UI组件库,提供了丰富的表单组件功能。实现动态增减表单项并设置表单回显有以下几个步骤: 1. 设置表单项初始值:在使用antd表单组件时,可以通过`initialValues`属性设置表单的初始值。假设有一个列表数据`list`,每个元素包含字段`name`和`value`,可以将其转化为初始值对象`initialValues`,其每个字段的值对应表单项的初始值。 2. 动态增减表单项:通过antd提供的`Form.List`组件,可以实现多个表单项的动态增减。在表单需要编辑和显示列表数据时,可以使用`map()`方法循环渲染表单项,并使用`remove()`方法删除不需要的表单项。 3. 表单项的读写绑定:在使用`Form.List`组件循环渲染表单项时,可以使用`name`属性将每个表单项与列表数据的对应字段关联起来,实现读写绑定。这样,当表单项的值发生变化时,列表数据的对应字段值也会随之更新。 4. 表单回显:在设置表单项初始值的基础上,antd的表单组件会自动将初始值回显到表单项,用户可以看到之前已经填写的内容。当删除或添加表单项时,表单组件会自动处理表单项的重新渲染和回显。 总结:通过设置表单项初始值、使用`Form.List`组件实现动态增减表单项、表单项的读写绑定以及antd的自动回显功能,可以实现antd动态增减表单项并设置表单回显的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值