Form 表单
表单支持数组和表单配置,示例中大部分使用了对象配置
基础用法(数组配置)
基础用法(对象配置)
内置组件
组件的props
下面的例子展示如果给组件添加props,props: (formInstance => Props) | Props
可以是函数或者是对象,item: (formInstance => Props) | Props
; 以下带选项的组件:select
、radio
、checkbox
可以通过设置 dataItemProps
来设置某项的props
插槽
可以通过定义type:"slot"
来实现插槽,作用域上可以获取formExpose
上所有API
组件的插槽
可以通过定义slots
来实现组件的插槽,目前支持input
、number
、select
、cascader
和扩展组件
扩展组件
自定义表单组件,只需要组件上实现 v-model
双向绑定,即可与表单一起使用。下面是一个很简单的选择图标的扩展组件的例子,你必须全局注册或在表单全局配置中
局部注册该组件;表单给组件传入了formExpose
上所有API和绑定了FromComponentOption
的props
和event
v1.0.2后
, 也可以传入VNode或者返回VNode的方法
自定义选择图标组件代码
<template>
<div>
<el-radio-group v-model="model" @change="emits('change', $event)">
<el-radio value="search">
<el-icon>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024" data-v-6fbb019e="">
<path
fill="currentColor"
d="m795.904 750.72 124.992 124.928a32 32 0 0 1-45.248 45.248L750.656 795.904a416 416 0 1 1 45.248-45.248zM480 832a352 352 0 1 0 0-704 352 352 0 0 0 0 704"
></path>
</svg>
</el-icon>
</el-radio>
<el-radio value="house">
<el-icon>
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024" data-v-6fbb019e="">
<path
fill="currentColor"
d="M192 413.952V896h640V413.952L512 147.328zM139.52 374.4l352-293.312a32 32 0 0 1 40.96 0l352 293.312A32 32 0 0 1 896 398.976V928a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V398.976a32 32 0 0 1 11.52-24.576"
></path>
</svg>
</el-icon>
</el-radio>
</el-radio-group>
</div>
</template>
<script lang="ts" setup>
defineOptions({
name: 'IconSelect'
})
const model = defineModel({ type: String })
const emits = defineEmits(['change'])
</script>
组件前置或者后置内容
可以使用prepend
和append
定义组件前置和后置内容,使用componentPrepend
和componentAppend
定义全部组件的前置和后置内容
带数据选项的组件
组件数据
异步数据
对于select
、radio
、checkbox
、cascader
类型组件,可以通过asyncData
配置组件的异步数据,asyncData
要求是一个函数,并返回Promise
;异步数据可自行解析,详情请看异步数据解析器
props和数据的联动性
组件间的数据联动
组件的显示与隐藏
表单验证(复杂验证)
当表单验证规则需要用到表单数据时,可以传入一个函数,函数返回类型为FormRules
Form Attributes
名称 | 说明 | 类型 | 默认值 |
---|---|---|---|
formProps | element plus表单属性 | object | {} |
options | 表单配置,支持数组 或者对象 形式 | object|array FormOptions | |
rules | 表单的验证规则,可以传入一个方法,方法参数接收表单实例 | object | (formInstance: FormInstance)=>object | {} |
model | 表单默认值 | object | |
autoGetAsyncData | 组件初始化时是否自动获取动态数据,在dialog 中使用时默认值为false | boolean | true |
componentPrepend | 组件的统一前置内容。接收一个方法,第一个参数是vue的渲染函数,第二个是表单暴露的实例 | (h: Function, formInstance: FormInstance)=> VNode | |
componentAppend | 组件的统一后置内容。同上 | (h: Function, formInstance: FormInstance)=> VNode | |
rowProps | el-row 的 props | object | null |
colProps | el-col 的 props | object | null |
FormOptions
formOptions分为FormObjectOptions
和FormObjectOptions
,都是由 FormComponentOption
组成,只是FormObjectOptions
每项上没有key
API配置
FormComponentOption
WARNING
注意 input
number
组件上没有 data
labelGetter
valueGetter
asyncData
dataItemProps
这5个API, cascader
上没有labelGetter
valueGetter
dataItemProps
这3个API
名称 | 说明 | 类型 | 是否必须 | 默认值 |
---|---|---|---|---|
key | 字段标识(仅存在于使用数组配置时) | string | 是 | |
type | 组件类型,input number select radio checkbox switch cascader date slot extend | string | 是 | |
label | form-item的label | string | 否 | |
props | 组件的props | object | 否 | |
show | 是否显示该表单项 | boolean | 否 | true |
colProps | el-col的props | object | 否 | {} |
formItemProps | from-item的props | object | 否 | {} |
prepend | 组件的前置内容 | (h: Function, formInstance: FormInstance) => VNode | VNode | 否 | |
append | 组件的后置内容 | (h: Function, formInstance: FormInstance) => VNode | VNode | 否 | |
event | 组件的事件 | (formInstance: FormInstance) => Record<string, Function> | 否 | {} |
slots | 组件的插槽,目前支持input 、number 、select 、cascader 和扩展组件 | (instance: FormInstance) => Record<string, VNode> | 否 | {} |
data | 下拉选项的数据 | object | array | 否 | [] |
labelGetter | 选项的label, 接收一个函数,第一个参数为每项数据,第二项为没项数组的索引(对象时为key) | (item: any, index: string | number) => any | 否 | |
valueGetter | 选项的value, 接收一个函数,第一个参数为每项数据,第二项为没项数组的索引(对象时为key) | (item: any, index: string | number) => any | 否 | |
asyncData | 异步数据,优先级比data高。 接收一个函数,第一个参数为FormInstance | (instance: FormInstance, ...args: any[]) => Promise<any> | 否 | |
dataItemProps | 每项数据的props | ((instance: FormInstance) => Object) | Object | 否 |
radio
组件特有的API
RadioOption
名称 | 说明 | 类型 | 是否必须 | 默认值 |
---|---|---|---|---|
button | 选项是否为button类型 | boolean | 否 | false |
checkbox
多选框组件特有的API
CheckboxOption
名称 | 说明 | 类型 | 是否必须 | 默认值 |
---|---|---|---|---|
button | 选项是否为button类型 | boolean | 否 | false |
extend
扩展组件特有的API
ExtendOption
名称 | 说明 | 类型 | 是否必须 | 默认值 |
---|---|---|---|---|
component | 组件 | string VNode v1.0.2新增 (formInstance: FormInstance) => VNode | null v1.0.2新增 | 否 | false |
Form Expose
表单暴露的属性和方法,ts类型为FormInstance
名称 | 说明 | 类型 |
---|---|---|
formData | 表单数据,为响应式数据 | object |
model | props传入的model | object |
elForm | element表单的实例 | object : MaybeRef<ElementPlus.FormInstance> |
getData | 获取表单的方法,返回一个promise,将会进行验证操作 | <T = any>() => Promise<T> |
componentData | 组件的数据(data或asyncData获得的数据) | object |
setData | 设置表单的数据 | (data: object) => void |
resetData | 重置表单的数据 | () => void |
getAsyncData | 获取异步数据 | (key?: string | string[]) => void |
execAsyncDataFunc | 执行异步数据的方法,即某项组件的asyncData方法 | (key: string, ...args: any[]) => void |
clearComponentData | 清空某项组件的数据,紧对带data 或asyncData 的组件有效 | (key: string | string[]) => void |