Vue3 Element Plus表單自定義校驗的實現(xiàn)全過程
一、效果
二、實現(xiàn)步驟
1.導(dǎo)入必要的組件和工具:
- 使用
import
語句導(dǎo)入Vue3的ref
、useRouter
,Element Plus的FormInstance
類型,以及自定義的接口和API。
import { ref } from "vue"; import type { FormInstance } from 'element-plus' import { useRouter } from "vue-router"; import { IUser2, IRules } from "@/interfaces/userInterface"; import { loginApi } from "@/apis/userApi"; import { User, Lock } from "@element-plus/icons-vue";
2.初始化數(shù)據(jù):
- 創(chuàng)建
ref
實例user2
,用于存儲用戶名和密碼。 - 創(chuàng)建
ref
實例ruleFormRef
,用于引用表單實例。 - 創(chuàng)建
ref
實例rules
,定義表單驗證規(guī)則,如用戶名和密碼的長度、格式等。
const $router = useRouter(); const user2 = ref<IUser2>({ account: "", password: "" }); const ruleFormRef = ref<FormInstance>() const rules = ref<IRules>({ account: [ { required: true, message: "請輸入用戶名", trigger: "blur" }, { pattern: /^[a-zA-Z0-9]{4,10}$/, message: "用戶名包含數(shù)字和字母大小寫4~10位", trigger: "blur" }, ], password: [ { required: true, message: "請輸入密碼", trigger: "blur" }, { pattern: /^[a-zA-Z0-9!@#$%^&*(),._-]{6,12}$/, message: "密碼包含數(shù)字和字母大小寫,特殊字符6~12位", trigger: "blur" } ] })
3.HTML模板:
- 使用
el-form
組件,設(shè)置ref
為ruleFormRef
,model
為user2
,rules
為rules
。 - 在
el-form-item
中使用el-input
組件,結(jié)合v-model
雙向綁定數(shù)據(jù),并設(shè)置prop
屬性與rules
中的屬性相對應(yīng),用于自動驗證。
<el-form class="login_form" ref="ruleFormRef" :model="user2" :rules="rules"> <h1>Hello</h1> <h2>歡迎來到白宮甄選</h2> <el-form-item class="login_item" prop="account"> <el-input :prefix-icon="User" placeholder="請輸入用戶名" v-model="user2.account"> </el-input> </el-form-item> <el-form-item class="login_item" prop="password"> <el-input type="password" placeholder="請輸入密碼" :prefix-icon="Lock" v-model="user2.password" show-password></el-input> </el-form-item> <el-form-item class="login_item"> <el-button class="login_btn" type="primary" @click="submitForm(ruleFormRef)">登陸 </el-button> </el-form-item> </el-form>
4.自定義校驗函數(shù):
- 定義
submitForm
函數(shù),接收表單實例作為參數(shù)。 - 在函數(shù)內(nèi)部,首先調(diào)用
validate
方法對表單進行驗證。如果驗證通過,調(diào)用登錄API并處理返回結(jié)果。如果驗證失敗,顯示錯誤通知。
const submitForm = (formEl: FormInstance | undefined) => { if (!formEl) return// 如果未定義表單實例,則直接返回,不執(zhí)行后續(xù)操作 // 驗證表單,如果驗證通過則調(diào)用登錄接口 formEl.validate(async(valid) => { if (valid) { // 調(diào)用登錄接口并傳入用戶信息 const res = await loginApi(user2.value); console.log(res); // 根據(jù)接口返回結(jié)果進行相應(yīng)操作 if (res.data.code !== 1) { ElNotification({ title: '登陸失敗', message: '用戶名或密碼錯誤', type: 'error', }) } else { // 登錄成功,存儲token并跳轉(zhuǎn)到首頁 localStorage.setItem("token", res.data.data.token); $router.push("/home"); ElNotification({ title: '登陸成功', message: '歡迎回來', type: 'success', }) } } else { // 驗證未通過,顯示錯誤通知 ElNotification({ title: '校驗', message: '請輸入用戶名和賬號', type: 'error', }) } }) }
三、重置該表單項并移除校驗結(jié)果
resetFields
:
resetFields這個方法在編輯或者修改的時候會出現(xiàn)問題 '重置為初始值',修改過后初始值依舊在但是可以移除校驗效果,想要到達真正的清空表單可以使用watch監(jiān)聽重新把表單對象賦值為空對象。
watch(() => { return open.value }, () => { if (!open.value) { form.value = {} } })
四、單詞意思
prop | 在使用了 validate、resetFields 的方法時,該屬性是必填的。 |
required | 是否為必填項。 |
message | 報錯提示消息。 |
trigger | 驗證邏輯的觸發(fā)方式 ----'blur' | 'change' |
blur | 失去焦點時進行驗證 |
change | 當值發(fā)生變化時進行驗證 |
pattern | 正則表達式,該值必須匹配才能通過驗證 |
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺談vue獲得后臺數(shù)據(jù)無法顯示到table上面的坑
這篇文章主要介紹了淺談vue獲得后臺數(shù)據(jù)無法顯示到table上面的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08vue-cli的index.html中使用環(huán)境變量方式
這篇文章主要介紹了vue-cli的index.html中使用環(huán)境變量方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10通過Element ui往頁面上加一個分頁導(dǎo)航條的方法
這篇文章主要介紹了通過Element ui往頁面上加一個分頁導(dǎo)航條的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05vue依賴包報錯問題eslint\lib\cli-engine\cli-engine.js:421
這篇文章主要介紹了vue依賴包報錯問題eslint\lib\cli-engine\cli-engine.js:421,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08Vue使用iframe實現(xiàn)瀏覽器打印兼容性優(yōu)化
在前端開發(fā)中,打印功能是一個常見的需求,但不同瀏覽器對打印樣式的支持差異較大,本文我們來看看Vue如何使用iframe實現(xiàn)瀏覽器打印兼容性優(yōu)化吧2025-04-04Vue中引用JSON數(shù)據(jù)的方法小結(jié)
在現(xiàn)代Web開發(fā)中,JSON是一種輕量級的數(shù)據(jù)交換格式,易于人閱讀和編寫,同時也易于機器解析和生成,Vue.js作為一個流行的前端框架,支持多種方式引入和處理JSON數(shù)據(jù),本文將詳細介紹幾種在Vue中引用JSON數(shù)據(jù)的方法,需要的朋友可以參考下2024-10-10vue?ElementUI級聯(lián)選擇器回顯問題解決
這篇文章主要介紹了vue?ElementUI級聯(lián)選擇器回顯問題解決,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09