Vue3表單組件el-form校驗規(guī)則rules屬性示例詳解
前言
在使用 Element UI (現(xiàn)在稱為 Element Plus) 的表單組件 el-form
時,rules
屬性用于定義表單項的校驗規(guī)則。這些規(guī)則可以幫助你確保用戶輸入的數(shù)據(jù)符合預期的格式和要求。
基本用法
rules
是一個對象,其中每個鍵對應一個表單項的字段名,值是一個或多個校驗規(guī)則。常見的校驗規(guī)則包括必填、數(shù)據(jù)類型、最小長度、最大長度、自定義校驗等。
示例代碼
以下是一個包含多個校驗規(guī)則的示例:
<template> <el-form :model="formData" :rules="rules" ref="form"> <el-form-item label="用戶名" prop="username"> <el-input v-model="formData.username"></el-input> </el-form-item> <el-form-item label="郵箱" prop="email"> <el-input v-model="formData.email"></el-input> </el-form-item> <el-form-item label="密碼" prop="password"> <el-input type="password" v-model="formData.password"></el-input> </el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form> </template> <script> export default { data() { return { formData: { username: '', email: '', password: '' }, rules: { username: [ { required: true, message: '用戶名不能為空', trigger: 'blur' }, { min: 3, max: 15, message: '用戶名長度應在3到15個字符之間', trigger: 'blur' } ], email: [ { required: true, message: '郵箱不能為空', trigger: 'blur' }, { type: 'email', message: '請輸入有效的郵箱地址', trigger: 'blur' } ], password: [ { required: true, message: '密碼不能為空', trigger: 'blur' }, { min: 6, max: 20, message: '密碼長度應在6到20個字符之間', trigger: 'blur' } ] } }; }, methods: { submitForm() { this.$refs.form.validate((valid) => { if (valid) { console.log('表單提交成功'); } else { console.log('表單校驗失敗'); return false; } }); } } }; </script>
校驗規(guī)則詳解
- required: 表示該字段是否為必填項。
- message: 校驗失敗時顯示的錯誤提示信息。
- trigger: 觸發(fā)校驗的時機,常見的值有
'blur'
和'change'
。 - type: 指定校驗的數(shù)據(jù)類型,如
'string'
、'number'
、'email'
、'url'
等。 - min 和 max: 指定字符串長度或數(shù)值的范圍,只在
type
為'string'
或'number'
時有效。 - 自定義校驗函數(shù): 可以通過
validator
屬性定義一個自定義的校驗函數(shù)。
自定義校驗函數(shù)示例
有時候內(nèi)置的校驗規(guī)則無法滿足需求,這時可以使用自定義校驗函數(shù):
rules: { password: [ { required: true, message: '密碼不能為空', trigger: 'blur' }, { min: 6, max: 20, message: '密碼長度應在6到20個字符之間', trigger: 'blur' }, { validator: validatePasswordStrength, trigger: 'blur' } ] } function validatePasswordStrength(rule, value, callback) { if (!/\d/.test(value)) { callback(new Error('密碼必須包含至少一個數(shù)字')); } else if (!/[a-zA-Z]/.test(value)) { callback(new Error('密碼必須包含至少一個字母')); } else { callback(); } }
在這個示例中,validatePasswordStrength
函數(shù)被用作自定義校驗函數(shù),確保密碼至少包含一個數(shù)字和一個字母。
附:更多自定義的校驗
例如:再次確認密碼的,在data中定義一個const 常量,在rules中引入
1. 在form表單中加入rules,并加上prop=‘’
<el-form ref="form" :model="form" :rules="rules" size="small" label-width="88px"> <el-form-item label="確認密碼" prop="confirmPass"> <el-input v-model="form.confirmPass" type="password" auto-complete="on" style="width: 370px;" /> </el-form-item> ... </el-form>
2.在data中定義一個const 常量
data(){ // 定義規(guī)則 (rule, value, callback) const confirmPass = (rule, value, callback) => { if (value) { if (this.form.newPass !== value) { callback(new Error('兩次輸入的密碼不一致')) } else { callback() } } else { callback(new Error('請再次輸入密碼')) } } ... }
3. 在rules中引入自定義的規(guī)則confirmPass
rules:{ oldPass: [ { required: true, message: '請輸入舊密碼', trigger: 'blur' } ], newPass: [ { required: true, message: '請輸入新密碼', trigger: 'blur' }, { min: 6, max: 20, message: '長度在 6 到 20 個字符', trigger: 'blur' } ], confirmPass: [ { required: true, validator: confirmPass, trigger: 'blur' } ] ... }
總結
通過合理配置 el-form
中的 rules
屬性,可以實現(xiàn)復雜的表單校驗邏輯,提升表單的易用性和數(shù)據(jù)的可靠性。根據(jù)具體需求選擇合適的校驗規(guī)則和觸發(fā)時機,是實現(xiàn)高質(zhì)量表單的關鍵。
到此這篇關于Vue3表單組件el-form校驗規(guī)則rules屬性的文章就介紹到這了,更多相關Vue3 el-form校驗規(guī)則rules屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法
下面小編就為大家分享一篇axios發(fā)送post請求springMVC接收不到參數(shù)的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03vue axios基于常見業(yè)務場景的二次封裝的實現(xiàn)
這篇文章主要介紹了vue axios基于常見業(yè)務場景的二次封裝的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09vue中展示、讀取.md?文件的方法(批量引入、自定義代碼塊高亮樣式)
這篇文章主要介紹了vue中展示、讀取.md?文件的方法(批量引入、自定義代碼塊高亮樣式),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05vue中defineProperty和Proxy的區(qū)別詳解
這篇文章主要介紹了vue中defineProperty和Proxy的區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11vue中動態(tài)路由加載組件,找不到module問題及解決
這篇文章主要介紹了vue中動態(tài)路由加載組件,找不到module問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06