ZBLOG

为了确保 rules 的错误消息不影响其他布局,您可以采用以下方法之一来设置样式,避免其撑大盒子。

方法一:使用绝对定位显示错误消息

通过使用绝对定位,可以将错误消息放置在输入框下方而不占据空间。下面是示例代码:

  1. <Form.Item
  2. label="每单可选物品上限:"
  3. name="goodsLimit"
  4. validateTrigger="onBlur"
  5. rules={[
  6. { required: true, message: '请输入每单可选物品上限' },
  7. {
  8. validator: (_, value) => {
  9. if (!value || (value >= 1 && value <= 99)) {
  10. return Promise.resolve();
  11. }
  12. return Promise.reject(new Error('请输入1~99之间的整数'));
  13. },
  14. },
  15. ]}
  16. labelCol={{ span: 24 }}
  17. wrapperCol={{ span: 24 }}
  18. style={{ position: 'relative' }} // 设置相对定位
  19. >
  20. <Input className="header-left-input" type="number" placeholder="请输入1~99之间的整数" />
  21. {/* 自定义错误提示位置 */}
  22. <Form.ErrorList>
  23. {(errors) => errors.length > 0 && (
  24. <div style={{
  25. color: 'red',
  26. position: 'absolute',
  27. top: '100%', // 显示在输入框下方
  28. left: 0,
  29. marginTop: 5,
  30. }}>
  31. {errors[0].message}
  32. </div>
  33. )}
  34. </Form.ErrorList>
  35. </Form.Item>

方法二:自定义样式和显示方式

您也可以选择隐藏原有的错误信息提示,并在验证失败时自己控制显示:

  1. import React from 'react';
  2. import { Form, Input } from 'antd';
  3. const CustomForm = () => {
  4. const [form] = Form.useForm();
  5. return (
  6. <Form form={form} layout="vertical">
  7. <Form.Item
  8. label="每单可选物品上限:"
  9. name="goodsLimit"
  10. validateTrigger="onBlur"
  11. rules={[
  12. { required: true, message: '' }, // 隐藏默认required提示
  13. {
  14. validator: (_, value) => {
  15. if (!value || (value >= 1 && value <= 99)) {
  16. return Promise.resolve();
  17. }
  18. return Promise.reject(new Error('')); // 同样隐藏默认提示
  19. },
  20. },
  21. ]}
  22. labelCol={{ span: 24 }}
  23. wrapperCol={{ span: 24 }}
  24. >
  25. <Input className="header-left-input" type="number" placeholder="请输入1~99之间的整数" />
  26. </Form.Item>
  27. {/* 自定义显示错误信息 */}
  28. <div style={{ color: 'red', marginTop: -10, height: '20px', display:'flex'}}>
  29. {form.getFieldError('goodsLimit').map((error, index) => (
  30. <span key={index}>{error}</span>
  31. ))}
  32. </div>
  33. </Form>
  34. );
  35. };
  36. export default CustomForm;

总结

通过这两种方式,可以有效防止错误提示撑大表单项,从而影响整个布局。在实现时,您可以根据需求选择合适的方法来调整效果。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=19114

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?