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>
相关推荐
xianxin_3 分钟前
CSS Outline(轮廓)
前端
moyu843 分钟前
遮罩层设计与实现指南
前端
timeweaver19 分钟前
深度解析 Nginx 前端 location 配置与优先级:你真的用对了吗?
前端·nginx·前端工程化
鲸落落丶20 分钟前
网络通信---Axios
前端
wwy_frontend21 分钟前
React性能优化实战:从卡顿到丝滑的8个技巧
前端·react.js
小高00736 分钟前
面试官:npm run build 到底干了什么?从 package.json 到 dist 的 7 步拆解
前端·javascript·vue.js
天选打工圣体37 分钟前
个人学习笔记总结(四)抽离elpis并发布npm包
前端
JayceM2 小时前
Vue中v-show与v-if的区别
前端·javascript·vue.js
HWL56792 小时前
“preinstall“: “npx only-allow pnpm“
运维·服务器·前端·javascript·vue.js
德育处主任2 小时前
p5.js 掌握圆锥体 cone
前端·数据可视化·canvas