VUE3+Element-plus中el-form的使用示例代碼
實現(xiàn)效果

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?

關(guān)鍵點
1.el-form的ref和model屬性的參數(shù)值必須不一樣,否則會沖突
2.每個el-form-item必須設(shè)置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>?增加表單項的校驗規(guī)則
如果要設(shè)置每個el-form-item的校驗規(guī)則,需要引入FormRules,安裝如下方式使用,關(guān)鍵點如下:
1.在el-form設(shè)置rules屬性
2.引入FormRules
3.聲明一個interface,例如RuleForm
4.使用reactive聲明model關(guān)聯(lián)的參數(shù)form,模板類型為RuleForm
5.使用reactive聲明rules關(guān)聯(lián)的參數(shù)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'}
]
)到此這篇關(guān)于VUE3+Element-plus中el-form的使用的文章就介紹到這了,更多相關(guān)vue3 Element-plus el-form使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實現(xiàn)input文本框只能輸入0-99的正整數(shù)問題
這篇文章主要介紹了vue實現(xiàn)input文本框只能輸入0-99的正整數(shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
vue3使用vue3-print-nb實現(xiàn)區(qū)域打印功能
這篇文章主要給大家介紹了關(guān)于vue3使用vue3-print-nb實現(xiàn)區(qū)域打印功能的相關(guān)資料,在日常操作中,相信很多人在Vue怎么用插件實現(xiàn)打印功能問題上存在疑惑,需要的朋友可以參考下2023-07-07
前端XSS攻擊場景詳解與Vue.js處理XSS的方法(vue-xss)
這篇文章主要給大家介紹了關(guān)于前端XSS攻擊場景與Vue.js使用vue-xss處理XSS的方法,介紹了實際工作中渲染數(shù)據(jù)時遇到XSS攻擊時的防范措施,以及解決方案,需要的朋友可以參考下2024-02-02
element-plus中el-table點擊單行修改背景色方法
這篇文章主要給大家介紹了關(guān)于element-plus中el-table點擊單行修改背景色的相關(guān)資料,這是產(chǎn)品新加了的一個需求,分享給同樣遇到這個需求的朋友,需要的朋友可以參考下2023-07-07
vue axios調(diào)用接口方法報錯500 internal server err
前端使用axios 訪問后端接口時報錯,在瀏覽器中點擊紅色的報錯數(shù)據(jù),本文給大家分享vue axios調(diào)用接口方法報錯500 internal server error的兩種解決方法,感興趣的朋友一起看看吧2023-10-10

