跳到主要内容

FormModal

将表单状态、变更执行和提交/重置操作整合到一个 Modal 对话框中的组件。

VEF 专属组件。 在 v2.1.6 中从 @vef-framework-react/starter 迁移到 @vef-framework-react/components

适用场景

  • 在 Modal 对话框中打开的新建和编辑表单。
  • 任何通过 MutationFunction 提交的表单。

基础用法

import { FormModal } from '@vef-framework-react/components';

interface UserForm {
name: string;
email: string;
}

export default function CreateUserModal({ open, onClose }) {
return (
<FormModal<UserForm>
open={open}
title="新建用户"
defaultValues={{ name: '', email: '' }}
mutationFn={createUser}
mutationMeta={{ invalidates: [[findUserPage.key]] }}
afterSubmit={() => onClose()}
onClose={onClose}
>
{(form) => (
<>
<form.AppField name="name">
{(field) => <field.Input label="姓名" required />}
</form.AppField>
<form.AppField name="email">
{(field) => <field.Input label="邮箱" required />}
</form.AppField>
</>
)}
</FormModal>
);
}

API

属性类型默认值说明
openbooleanfalse是否显示 Modal
titleReactNodeModal 标题
widthstring | numberModal 宽度
draggablebooleantrue是否可拖拽
defaultValuesTValues表单初始值
disabledbooleanfalse禁用表单
mutationFnMutationFunction<ApiResult<TData>, TValues>提交时执行的变更函数
mutationMetaMutationMeta变更元数据(如 invalidates
beforeSubmit(values) => Awaitable<TValues>提交前转换值
afterSubmit(values, data) => Awaitable<void>提交成功后回调
onSubmit(values) => Awaitable<void>自定义提交处理(替代 mutationFn
onReset(defaultValues?) => void重置时回调
onClose() => voidModal 关闭时回调
renderActions(formApi) => ReactNode自定义底部操作;返回 null 隐藏底部
submitButtonPropsSubmitButtonProps提交按钮自定义
resetButtonPropsResetButtonProps | false重置按钮自定义;false 隐藏
childrenReactNode | (formApi) => ReactNode表单内容