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-10vue3使用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-02element-plus中el-table點擊單行修改背景色方法
這篇文章主要給大家介紹了關(guān)于element-plus中el-table點擊單行修改背景色的相關(guān)資料,這是產(chǎn)品新加了的一個需求,分享給同樣遇到這個需求的朋友,需要的朋友可以參考下2023-07-07vue axios調(diào)用接口方法報錯500 internal server err
前端使用axios 訪問后端接口時報錯,在瀏覽器中點擊紅色的報錯數(shù)據(jù),本文給大家分享vue axios調(diào)用接口方法報錯500 internal server error的兩種解決方法,感興趣的朋友一起看看吧2023-10-10