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

Element-plus使用el-form必須配置ref和model屬性,二者的值不能相同(在ElementUI中是可以相同的)。ref的值在聲明的時(shí)候要引入FormInstance,這個(gè)又必須在script中聲明lang為ts,不能使用js。這樣就必須引入對(duì)ts的支持?
step 1:安裝vue-loader和vue-template-compiler

step 2:安裝typescript?

step 3:安裝ts-loader?

關(guān)鍵點(diǎn)
1.el-form的ref和model屬性的參數(shù)值必須不一樣,否則會(huì)沖突
2.每個(gè)el-form-item必須設(shè)置prop屬性,否則重置方法resetFields不生效
3.重置方法使用的formRef后面需要增加.value,因?yàn)槁暶鞯氖莚ef。否則重置方法resetFields不生效
4.要控制表單項(xiàng)的布局,使用el-row和el-col是不錯(cuò)的方法,易于控制
完整代碼
?<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>?增加表單項(xiàng)的校驗(yàn)規(guī)則
如果要設(shè)置每個(gè)el-form-item的校驗(yàn)規(guī)則,需要引入FormRules,安裝如下方式使用,關(guān)鍵點(diǎn)如下:
1.在el-form設(shè)置rules屬性
2.引入FormRules
3.聲明一個(gè)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: '請(qǐng)輸入郵箱', trigger: 'blur'},
{type: 'email', message: '請(qǐng)輸入正確的郵箱地址', trigger: ['blur', 'change']}
],
name: [
{required: true, message: '請(qǐng)輸入姓名', trigger: 'blur'}
]
)到此這篇關(guān)于VUE3+Element-plus中el-form的使用的文章就介紹到這了,更多相關(guān)vue3 Element-plus el-form使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 基于Vue3和Element Plus實(shí)現(xiàn)可擴(kuò)展的表格組件
- Vue3+Element Plus實(shí)現(xiàn)自定義彈窗組件的全屏功能
- vue3+js+elementPlus使用富文本編輯器@vueup/vue-quill詳細(xì)教程
- vue-treeselect(適配Vue3.2)及Element-plus的TreeSelect組件使用
- vue3基于elementplus 簡(jiǎn)單實(shí)現(xiàn)表格二次封裝過(guò)程
- vue3?element?plus?table?selection展示數(shù)據(jù),默認(rèn)選中功能方式
相關(guān)文章
使用寶塔面板中Nginx部署前端Vue項(xiàng)目完整步驟
在Kubernetes(K8S)部署前端Vue項(xiàng)目通常會(huì)涉及到使用Nginx作為靜態(tài)資源服務(wù)器的一個(gè)重要部分,這篇文章主要給大家介紹了關(guān)于使用寶塔面板中Nginx部署前端Vue項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2024-10-10
vue實(shí)現(xiàn)input文本框只能輸入0-99的正整數(shù)問(wèn)題
這篇文章主要介紹了vue實(shí)現(xiàn)input文本框只能輸入0-99的正整數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
vue3 與 vue2 優(yōu)點(diǎn)對(duì)比匯總
隨著用vue3 的開發(fā)者越來(lái)越多,其必定是又她一定的有帶你,接下來(lái)這篇文章小編就為大家介紹vue3 對(duì)比 vue2 有什么優(yōu)點(diǎn)?感興趣的小伙伴請(qǐng)跟小編一起閱讀下文吧2021-09-09
vue中點(diǎn)擊下載圖片的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于vue中點(diǎn)擊下載圖片的實(shí)現(xiàn)方法,在Vue的模板中,我們可以將下載屬性綁定至或元素上,用來(lái)實(shí)現(xiàn)點(diǎn)擊下載,需要的朋友可以參考下2023-08-08
vue3使用vue3-print-nb實(shí)現(xiàn)區(qū)域打印功能
這篇文章主要給大家介紹了關(guān)于vue3使用vue3-print-nb實(shí)現(xiàn)區(qū)域打印功能的相關(guān)資料,在日常操作中,相信很多人在Vue怎么用插件實(shí)現(xiàn)打印功能問(wèn)題上存在疑惑,需要的朋友可以參考下2023-07-07
前端XSS攻擊場(chǎng)景詳解與Vue.js處理XSS的方法(vue-xss)
這篇文章主要給大家介紹了關(guān)于前端XSS攻擊場(chǎng)景與Vue.js使用vue-xss處理XSS的方法,介紹了實(shí)際工作中渲染數(shù)據(jù)時(shí)遇到XSS攻擊時(shí)的防范措施,以及解決方案,需要的朋友可以參考下2024-02-02
element-plus中el-table點(diǎn)擊單行修改背景色方法
這篇文章主要給大家介紹了關(guān)于element-plus中el-table點(diǎn)擊單行修改背景色的相關(guān)資料,這是產(chǎn)品新加了的一個(gè)需求,分享給同樣遇到這個(gè)需求的朋友,需要的朋友可以參考下2023-07-07
vue3封裝數(shù)字滾動(dòng)組件的實(shí)現(xiàn)示例
本文主要介紹了vue3封裝數(shù)字滾動(dòng)組件的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08
vue axios調(diào)用接口方法報(bào)錯(cuò)500 internal server err
前端使用axios 訪問(wèn)后端接口時(shí)報(bào)錯(cuò),在瀏覽器中點(diǎn)擊紅色的報(bào)錯(cuò)數(shù)據(jù),本文給大家分享vue axios調(diào)用接口方法報(bào)錯(cuò)500 internal server error的兩種解決方法,感興趣的朋友一起看看吧2023-10-10

