VUE3+Element-plus中el-form的使用示例代码
实现效果
Element-plus使用el-form必须配置ref和model属性,二者的值不能相同(在ElementUI中是可以相同的)。ref的值在声明的时候要引入FormInstance,这个又必须在script中声明lang为ts,不能使用js。这样就必须引入对ts的支持
step 1:安装vue-loader和vue-template-compiler
step 2:安装typescript
step 3:安装ts-loader
关键点
1.el-form的ref和model属性的参数值必须不一样,否则会冲突
2.每个el-form-item必须设置prop属性,否则重置方法resetFields不生效
3.重置方法使用的formRef后面需要增加.value,因为声明的是ref。否则重置方法resetFields不生效
4.要控制表单项的布局,使用el-row和el-col是不错的方法,易于控制
完整代码
<template> <div> <el-form :model="form" ref="formRef" > <el-row> <el-col :span="10"> <el-form-item label="邮箱" prop="email"> <el-input v-model="form.email"></el-input> </el-form-item> </el-col> <el-col :span="10"> <el-form-item label="姓名" prop="name"> <el-input v-model="form.name"></el-input> </el-form-item> </el-col> </el-row> <el-form-item> <el-button type="primary" @click="submitForm(productId,username)">提交</el-button> <el-button @click="resetForm">重置</el-button> </el-form-item> </el-form> </div> </template> <script lang="ts" setup> import type {FormInstance} from "element-plus"; const formRef=ref<FormInstance>() function resetForm() { console.log('this.form',form) formRef.value.resetFields() } </script>
增加表单项的校验规则
如果要设置每个el-form-item的校验规则,需要引入FormRules,安装如下方式使用,关键点如下:
1.在el-form设置rules属性
2.引入FormRules
3.声明一个interface,例如RuleForm
4.使用reactive声明model关联的参数form,模板类型为RuleForm
5.使用reactive声明rules关联的参数curRules,模板类型为FormRules<RuleForm>
<el-form :model="form" ref="formRef" :rules="curRules"> //... import type {FormRules} from "element-plus"; interface RuleForm{ email: String name: String } let form=reactive<RuleForm>({ email: '', name: '', }) let curRules=reactive<FormRules<RuleForm>>({ email: [ {required: true, message: '请输入邮箱', trigger: 'blur'}, {type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change']} ], name: [ {required: true, message: '请输入姓名', trigger: 'blur'} ] )
到此这篇关于VUE3+Element-plus中el-form的使用的文章就介绍到这了,更多相关vue3 Element-plus el-form使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
elementUI checkBox报错Cannot read property &ap
这篇文章主要为大家介绍了elementUI checkBox报错Cannot read property 'length' of undefined的解决分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-06-06vue中利用pinyin-pro纯前端实现拼音的模糊搜索功能
这篇文章主要介绍了vue中利用pinyin-pro纯前端实现拼音的模糊搜索,实现思路很简单,通过安装配置插件编写工具类,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下2022-11-11
最新评论