Skip to content
On this page

Ant Design Pro Form

Basic Usage

Demo Examples

Install

bash
# yarn
yarn add @ant-design-vue/pro-form
# npm
npm i @ant-design-vue/pro-form -S

Simple Usage

js
// main.[js|ts]
import "@ant-design-vue/pro-form/dist/style.css"; // pro-form css or style.less
vue
<template>
  <QueryFilter
    :model="formModel"
    @finish="handleSubmit"
    @collapsed="onCollapsed"
  >
    <FormItem name="name" label="应用名称" required>
      <Input v-model:value="formModel.name" placeholder="请输入" allow-clear />
    </FormItem>
    <FormItem name="creater" label="创建人" required>
      <Input v-model:value="formModel.creater" placeholder="请输入" />
    </FormItem>
    <FormItem name="sex" label="性别" required>
      <Select v-model:value="formModel.sex">
        <SelectOption
          v-for="item in sex"
          :key="item.value"
          :value="item.value"
          >{{ item.label }}</SelectOption
        >
      </Select>
    </FormItem>
    <FormItem name="status" label="应用状态">
      <Input v-model:value="formModel.status" placeholder="请输入" />
    </FormItem>
    <FormItem name="startDate" label="响应日期">
      <DatePicker v-model:value="formModel.startDate" placeholder="请输入" />
    </FormItem>
    <FormItem name="create" label="创建时间">
      <RangePicker
        v-model:value="formModel.create"
        :placeholder="['开始时间', '结束时间']"
      />
    </FormItem>
  </QueryFilter>
</template>

<script lang="ts" setup>
import { ref, reactive } from "vue";
import { QueryFilter } from "@ant-design-vue/pro-form";
import dayjs, { type Dayjs } from "dayjs";
import {
  FormItem,
  Input,
  Select,
  SelectOption,
  RangePicker,
  DatePicker,
} from "ant-design-vue";

const formModel = reactive({
  name: "123",
  creater: "11",
  sex: "",
  status: "",
  startDate: "",
  create: [
    dayjs("2015/01/01", "YYYY/MM/DD"),
    dayjs("2016/01/01", "YYYY/MM/DD"),
  ] as [Dayjs, Dayjs],
});
const sex = ref([
  {
    value: "",
    label: "",
  },
  {
    value: "",
    label: "",
  },
]);

function handleSubmit(params: any) {
  console.log(params);
}
function onCollapsed(collapsed: boolean) {
  console.log(collapsed);
}
</script>

API

ProLayout

PropertyDescriptionTypeDefault Value
formPropsantd 基础表单 propsobject
searchGutter表单 gutternumber24
style自定义样式objectundefined
defaultColsNumber自定义折叠状态下默认显示的表单控件数量,没有设置或小于 0,则显示一行控件; 数量大于等于控件数量则隐藏展开按钮Numberundefined
collapsed是否折叠超出的表单项,用于受控模式Booleanundefined
defaultCollapsed默认状态下是否折叠超出的表单项Booleantrue
preserve是否能够查询收起的数据,如果设置为 false,收起后的表单数据将会丢失Booleantrue
split每一行是否有分割线Booleanundefined
submitButtonProps提交按钮的 propsObjectundefined
submitter重置、查询、展开收起按钮 propsSubmitterPropsundefined
onCollapsed切换表单折叠状态时的回调(collapsed: boolean) => voidundefined
onFinish表单提交(fromModel: any) => voidundefined
onSubmit表单提交(fromModel: any) => voidundefined
onReset重置表单(fromModel: any) => voidundefined

Build project

bash
pnpm build # Build library and .d.ts

TODO:

  • [x] BaseFrom
  • [x] QueryFilter
  • [x] ProForm
    • [x] ProField
    • [ ] 更多原子组件...
  • [ ] LoginFrom
  • [ ] ModalFrom
  • [ ] DrawerFrom
  • [ ] ProTable