form.item接管受控组件

先回顾一下 React 的受控组件

  • 普通受控组件(例如 SwitchInput):
    你需要自己传 value/checkedonChange,手动管理 state。
ini 复制代码
const [checked, setChecked] = useState(false);

<Switch checked={checked} onChange={setChecked} />;

这里 Switch 的状态完全由外层 state 控制。

📦 Antd Form.Item 的做法

Form.Item 让你不必自己写 state + onChange,它会:

  1. 读取表单的值(Form store 里的值)。
  2. 把值传递给子组件 (通过 valuePropNamegetValueProps)。
  3. 拦截子组件的事件 (通过 trigger,默认是 onChange),自动更新 Form store。

✅自己封装的受控组件一样可以被 Form.Item 接管,只要满足 受控组件的契约

🔑 什么样的组件能被 Form.Item 接管?

一个组件想要被 Form.Item 接管,至少要符合这几点:

  1. 有一个"值"属性

    比如 valuechecked,由外部传入。

  2. 有一个"触发变更"的事件

    比如 onChange,当用户交互时调用,并把新值传出去。

  3. Form.Item 上声明:

    • valuePropName → 指定用哪个属性当值(value / checked)。
    • trigger → 指定用哪个事件更新值(默认是 onChange)。

这样 Form.Item 就能拦截你的组件,帮你和表单 store 打通。


🌰 举个例子

比如你自己封装了一个组件:

typescript 复制代码
interface MySwitchProps {
  value?: boolean;  // 外部控制的值
  onChange?: (value: boolean) => void;  // 值变化时的回调
}

const MySwitch: React.FC<MySwitchProps> = ({ value = false, onChange }) => {
  return (
    <button
      style={{
        background: value ? "green" : "red",
        color: "white",
        padding: "4px 8px"
      }}
      onClick={() => onChange?.(!value)}
    >
      {value ? "开" : "关"}
    </button>
  );
};

这是一个完全受控的组件。

放到表单里,就能自动接管:

ini 复制代码
<Form.Item
  label="自定义开关"
  name="mySwitch"
  valuePropName="value"   // 指定组件的受控属性
>
  <MySwitch />
</Form.Item>

🧩 再复杂点:属性名不是 value

假设你写的组件属性是 checked 而不是 value

typescript 复制代码
interface MyToggleProps {
  checked?: boolean;
  onChange?: (checked: boolean) => void;
}

那么 Form.Item 要这样写:

ini 复制代码
<Form.Item
  label="自定义 Toggle"
  name="myToggle"
  valuePropName="checked"   // 告诉表单用 checked 作为值
>
  <MyToggle />
</Form.Item>

✅ 结论:你自己封装的任何受控组件,都可以被 Form.Item 托管,只要有「值属性 + 触发事件」,并正确配置 valuePropName / trigger

ini 复制代码
<Form.Item
  name="myToggle"
  valuePropName="checked"       // 指定值的属性名
  trigger="onCheckedChange"     // 指定触发更新的事件名
>
  <MyToggle />
</Form.Item>
相关推荐
主宰者10 分钟前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#
前端小咸鱼一条39 分钟前
16.迭代器 和 生成器
开发语言·前端·javascript
小江的记录本1 小时前
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
java·前端·spring boot·后端·spring·mybatis·web
web守墓人1 小时前
【前端】记一次将ruoyi vue3 element-plus迁移到arco design vue的经历
前端·vue.js·arco design
伊步沁心1 小时前
Webpack & Vite 深度解析
前端
libokaifa1 小时前
OpenSpec + TDD:让 AI 写代码,用测试兜底
前端·ai编程
用户15815963743701 小时前
搭 AI Agent 团队踩了 18 个坑,总结出这 5 个关键步骤
前端
Kellen1 小时前
Fumadocs 基础概念:从内容源到页面渲染
前端
Lee川1 小时前
前端进阶之路:从性能优化到响应式布局的实战指南(Tailwindcss)
前端·面试
努力干饭中1 小时前
Git Rebase 最佳实践
前端·git