elemenplus form表单的动态配置写法
elementplus form的动态配置写法
模板代码部分
<template>
<div class="card content-box">
<el-alert title="通过 component :is 组件属性 && v-bind 属性透传,可以将 template 中的 html 代码全部改变为 columns 配置项,具体配置请看代码。" type="warning" :closable="false" />
<component :is="'el-form'" v-bind="options.form" ref="proFormRef" :model="formData" :rules="formRules">
<!-- 动态表单 -->
<el-row style="width:100%" :gutter="0">
<template v-for="item in options.columns" :key="item.prop">
<el-col :span="item.formItem.span">
<component :is="'el-form-item'" v-bind="item.formItem">
<component :is="`el-${item.attrs.typeName}`" v-bind="item.attrs" v-model="formData[item.formItem.prop]" />
</component>
</el-col>
</template>
</el-row>
<!-- 提交按钮 -->
<el-form-item>
<el-button type="primary" @click="submitForm(proFormRef)">提交</el-button>
<el-button @click="resetForm(proFormRef)">重置</el-button>
</el-form-item>
</component>
</div>
</template>
ts代码部分
<script setup lang="ts" name="proForm">
import type { FormInstance, FormRules } from "element-plus";
import { checkPhoneNumber } from "@/utils/eleValidate";
import { ElMessage } from "element-plus";
const proFormRef = ref<FormInstance>();
// 表单提交字段
const formData = reactive<Record<string, any>>({
username: "",
password: "",
phone: "",
email: "",
email2: ""
})
// 表单的验证
const formRules = reactive<FormRules>({
phone: [{ required: true, validator: checkPhoneNumber, trigger: "blur" }],
})
// 表单的配置项
const options = ref({
// 表单整体配置项
form: {
labelPosition: "right",
labelWidth: "80px",
size: "default",
labelSuffix: " :",
},
// 表单列配置项 (formItem 代表 item 配置项,attrs 代表 输入、选择框 配置项)
columns: [
{
formItem: { label: "用户名", span: 24, prop: "username", labelWidth: "80px", required: false },
attrs: { typeName: "input", placeholder: "请输入用户名", autofocus: true, clearable: true, disabled: false }
},
{
formItem: { label: "密码", span: 12, prop: "password", class: "data" },
attrs: { typeName: "input", placeholder: "请输入密码", type: "password", clearable: true, }
},
{
formItem: { label: "手机号", span: 24, prop: "phone" },
attrs: { typeName: "input", placeholder: "请输入邮箱", clearable: true }
},
{
formItem: { label: "邮箱", span: 12, prop: "email" },
attrs: { typeName: "input", placeholder: "请输入邮箱", clearable: true }
},
{
formItem: { label: "邮箱", span: 12, prop: "email2" },
attrs: { typeName: "input", placeholder: "请输入邮箱", clearable: true }
}
],
});
// 提交表单
const submitForm = async (formEl: FormInstance | undefined) => {
if (!formEl) return;
await formEl.validate((valid, fields) => {
if (valid) {
ElMessage.success("提交的数据为 : " + JSON.stringify(formData));
} else {
console.log("error submit!", fields);
}
});
};
// 充值表单
const resetForm = (formEl: FormInstance | undefined) => {
if (!formEl) return;
formEl.resetFields();
};
</script>
洗尽铅华始见金,褪去浮华归本真
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现