表单配置
本文将介绍如何设置表单配置中的UI相关配置,并详细说明各个配置项的作用。
设置表单配置
以下是设置表单配置的方法:
- 组件模式
在模板中设置表单配置:
html
<form-create :option="option"></form-create>- 全局方法
你还可以通过全局方法创建表单并设置表单配置:
js
window.formCreate.create(rule, option)构成
全局配置中额外支持一下配置项
- form:表单整体显示规则配置
- row:表单组件布局配置
- submitBtn:提交按钮样式配置
- resetBtn:重置按钮样式配置
- info:组件提示消息配置
- wrap: 配置
FormItem
配置表单(form)
类型:
Object说明:配置表单的整体显示规则,比如标签对齐方式和输入框对齐方式。
默认值:
js
{
inline: false,
labelPlacement: 'left',
labelWidth: '125px',
disabled: false,
size: undefined,
}- 完整配置项: Form props
配置示例
基础配置
js
const option = {
form: {
labelPlacement: 'left', // 标签位置: 'left' | 'top' | 'right'
labelWidth: '125px', // 标签宽度
size: 'medium' // 表单尺寸
}
}标签顶部对齐
js
const option = {
form: {
labelPlacement: 'top' // 标签在顶部
}
}标签右对齐
js
const option = {
form: {
labelPlacement: 'right' // 标签在右侧
}
}行内表单
js
const option = {
form: {
inline: true // 行内表单模式
}
}设置表单尺寸
js
const option = {
form: {
size: 'large' // 可选值: 'tiny' | 'small' | 'medium' | 'large'
}
}配置布局(row)
类型:
Object说明:配置表单组件的布局,比如组件之间的间距。
默认值:
js
{
gutter: 0,
}- 完整配置项: Row props
配置示例
设置栅格间隔
js
const option = {
row: {
gutter: 16 // 设置栅格间隔为16px
}
}配置提交按钮(submitBtn)
类型:
Object说明:配置提交按钮的样式和布局。
默认值:
js
{
type: 'primary',
loading: false,
disabled: false,
innerText: '提交',
show: true,
col: undefined,
click: undefined,
}如果不需要显示提交按钮,可以将 submitBtn 设置为 false 或 submitBtn.show 设置为 false。
- 完整配置项: 布局规则 | Button_props
配置示例
基础配置
js
const option = {
submitBtn: {
innerText: '提交',
type: 'primary',
show: true
}
}自定义按钮文字和样式
js
const option = {
submitBtn: {
innerText: '保存',
type: 'primary',
size: 'large'
}
}隐藏提交按钮
js
const option = {
submitBtn: false // 或 submitBtn: { show: false }
}自定义按钮布局
js
const option = {
submitBtn: {
innerText: '提交',
col: {
span: 12, // 按钮占据12列
offset: 6 // 左侧偏移6列
}
}
}自定义提交事件
js
const option = {
submitBtn: {
innerText: '提交',
click: (formData, fApi) => {
console.log('提交数据:', formData)
// 自定义提交逻辑
return false // 返回 false 阻止默认提交
}
}
}配置重置按钮(resetBtn)
类型:
Object说明:配置重置按钮的样式和布局。
默认值:
js
{
type: 'default',
loading: false,
disabled: false,
innerText: '重置',
show: false,
col: undefined,
click: undefined,
}如果需要显示重置按钮,可以将 resetBtn 设置为 true 或 resetBtn.show 设置为 true。
- 完整配置项: 布局规则 | Button_props
配置示例
显示重置按钮
js
const option = {
resetBtn: {
show: true,
innerText: '重置',
type: 'default'
}
}自定义重置按钮样式
js
const option = {
resetBtn: {
show: true,
innerText: '清空',
type: 'tertiary',
size: 'large'
}
}自定义重置事件
js
const option = {
resetBtn: {
show: true,
innerText: '重置',
click: (fApi) => {
console.log('重置表单')
// 自定义重置逻辑
fApi.resetFields() // 重置表单字段
}
}
}悬浮提示框(info)
类型:
Object说明:组件提示消息配置
默认值:
js
{
type: 'popover',
placement: 'top-start',
icon: 'icon-info'
}可以在info配置项中设置提示组件的属性
- 提示组件: Popover_props | Tooltip_props
配置示例
使用 Popover 提示
js
const option = {
info: {
type: 'popover',
placement: 'top-start', // 可选值: 'top' | 'top-start' | 'top-end' | 'bottom' | 'bottom-start' | 'bottom-end' | 'left' | 'left-start' | 'left-end' | 'right' | 'right-start' | 'right-end'
icon: 'icon-info',
content: '这是字段说明'
}
}使用 Tooltip 提示
js
const option = {
info: {
type: 'tooltip',
placement: 'top',
icon: 'icon-info',
content: '这是字段说明'
}
}自定义提示图标
js
const option = {
info: {
type: 'popover',
placement: 'top-start',
icon: 'icon-warning', // 自定义图标
content: '请仔细填写此字段'
}
}禁用提示
js
const option = {
info: false // 或 info: { show: false }
}配置 FormItem(wrap)
类型:
Object说明:配置
FormItem组件的显示规则,例如字段的样式和布局。完整配置项: FormItem_props
配置示例
全局设置标签宽度
js
const option = {
wrap: {
labelWidth: '150px' // 全局标签宽度
}
}完整配置示例
js
const option = {
// 表单整体配置
form: {
labelPlacement: 'left',
labelWidth: '125px',
size: 'medium'
},
// 栅格布局配置
row: {
gutter: 16
},
// 提交按钮配置
submitBtn: {
innerText: '提交',
type: 'primary',
show: true
},
// 重置按钮配置
resetBtn: {
show: true,
innerText: '重置',
type: 'default'
},
// 提示信息配置
info: {
type: 'popover',
placement: 'top-start',
icon: 'icon-info'
},
// FormItem 配置
wrap: {
labelWidth: '125px'
}
}

