實現(xiàn)elementUI表單的全局驗證的方法步驟
使用ElementUi搭建框架的時候,大家應(yīng)該都有考慮過怎么做全局驗證,畢竟復(fù)制粘貼什么的是最煩了,這里分享下個人的解決方法。
驗證規(guī)則
分析規(guī)則
一般驗證規(guī)則,主要是是否必填,不為空,以及參數(shù)類型的驗證。 基于這個條件,我們開始找找思路, 單個字段的驗證是這樣的:
name: {
required: 是否必填,
validator: 自定義規(guī)則,
message: 失敗提示消息(非自定義時觸發(fā)),
trigger: 觸發(fā)方式
}
循環(huán)實現(xiàn)
固定的規(guī)則。當(dāng)一個東西固定之后,那必然是可以重復(fù)使用的,并且可以快速生成,我們可以用循環(huán)來實現(xiàn)它。 但是用循環(huán)來實現(xiàn),我們則需要一個數(shù)據(jù)規(guī)則。
定義數(shù)據(jù)規(guī)則
分析下需要的字段,大概就是以下幾種,其他的可以根據(jù)自身的需求去增加:
- 驗證的字段名 label
- 驗證的值 value
- 驗證的類型 type
- 是否必填 required
- 自定義規(guī)則 validator
那最終我們得到的是這樣一個字段配置列表:
fieldList: [
{label: '賬號', value: 'account', type: 'input', required: true, validator: checkAccount},
{label: '密碼', value: 'password', type: 'password', required: true, validator: checkPwd},
{label: '昵稱', value: 'name', type: 'input', required: true},
{label: '性別', value: 'sex', type: 'select', list: 'sexList', required: true},
{label: '頭像', value: 'avatar', type: 'slot', className: 'el-form-block'},
{label: '手機(jī)號碼', value: 'phone', type: 'input', validator: checkPhone},
{label: '微信', value: 'wechat', type: 'input', validator: checkWechat},
{label: 'QQ', value: 'qq', type: 'input', validator: checkQQ},
{label: '郵箱', value: 'email', type: 'input', validator: checkEmail},
{label: '描述', value: 'desc', type: 'textarea', className: 'el-form-block'},
{label: '狀態(tài)', value: 'status', type: 'select', list: 'statusList', required: true}
]
form完整的字段配置建議參考:
formInfo: {
ref: null,
data: {
id: '', // *唯一ID
account: '', // *用戶賬號
password: '', // *用戶密碼
name: '', // *用戶昵稱
type: 2, // *用戶類型: 0: 手機(jī)注冊 1: 論壇注冊 2: 管理平臺添加
sex: 0, // *性別: 0:男 1:女
avatar: '', // 頭像
phone: '', // 手機(jī)號碼
wechat: '', // 微信
qq: '', // qq
email: '', // 郵箱
desc: '', // 描述
status: 1 // *狀態(tài): 0:停用,1:啟用(默認(rèn)為1)',
// create_user: '', // 創(chuàng)建人
// create_time: '', // 創(chuàng)建時間
// update_user: '', // 修改人
// update_time: '' // 修改時間
},
fieldList: [
{label: '賬號', value: 'account', type: 'input', required: true, validator: checkAccount},
{label: '密碼', value: 'password', type: 'password', required: true, validator: checkPwd},
{label: '昵稱', value: 'name', type: 'input', required: true},
{label: '性別', value: 'sex', type: 'select', list: 'sexList', required: true},
{label: '頭像', value: 'avatar', type: 'slot', className: 'el-form-block'},
{label: '手機(jī)號碼', value: 'phone', type: 'input', validator: checkPhone},
{label: '微信', value: 'wechat', type: 'input', validator: checkWechat},
{label: 'QQ', value: 'qq', type: 'input', validator: checkQQ},
{label: '郵箱', value: 'email', type: 'input', validator: checkEmail},
{label: '描述', value: 'desc', type: 'textarea', className: 'el-form-block'},
{label: '狀態(tài)', value: 'status', type: 'select', list: 'statusList', required: true}
],
rules: {},
labelWidth: '120px'
}
實現(xiàn)驗證方法
一: 循環(huán)字段列表,根據(jù)type判斷是提示選擇不能為空,還是輸入不能為空
二:如果字段必填,則根據(jù)是否有自定義驗證去生成驗證規(guī)則
三: 字段非必填,有自定義規(guī)則生成驗證
// 初始化驗證數(shù)據(jù)
_initValidate (formInfo) {
const obj = {},
fieldList = formInfo.fieldList
// 循環(huán)字段列表
for (let item of fieldList) {
let type = item.type === 'select' ? '選擇' : '輸入'
if (item.required) {
if (item.validator) {
obj[item.value] = {
required: item.required,
validator: item.validator,
trigger: 'blur'
}
} else {
obj[item.value] = {
required: item.required,
message: '請' + type + item.label,
trigger: 'blur'
}
}
} else if (item.validator) {
obj[item.value] = {
validator: item.validator,
trigger: 'blur'
}
}
}
formInfo.rules = obj
}
使用
結(jié)合上面的字段設(shè)計,我在頁面上的使用是這樣的,大家可以根據(jù)自己的字段設(shè)計去修改,大致實現(xiàn)過程是這樣的
// mixin中的方法, 初始化字段驗證規(guī)則 this._initValidate(this.formInfo)
怎么配置到全局
- 通過mixin配置,然后在頁面中使用(個人使用的是mixin)
- 配置為全局方法在頁面中調(diào)用
- 掛在到vue實例上,通過this即可訪問
mixins例子
export default {
data () {
/**
* 頁面上的可復(fù)用的驗證規(guī)則
*/
// 驗證號碼格式
const CHECK_PHONE = (rule, value, callback) => {
let check = this.$validate({label: '號碼', value, rules: ['phone']})
if (!check.result) {
callback(new Error(check.message))
} else {
callback()
}
}
// 驗證號碼格式以及不能為空
const CHECK_PHONE_NOTNULL = (rule, value, callback) => {
let check = this.$validate({label: '號碼', value, rules: ['notnull', 'phone']})
if (!check.result) {
callback(new Error(check.message))
} else {
callback()
}
}
// 檢測郵箱格式
const CHECK_EMAIL = (rule, value, callback) => {
let check = this.$validate({label: '郵箱', value, rules: ['email']})
if (!check.result) {
callback(new Error(check.message))
} else {
callback()
}
}
// 檢測郵箱格式以及不能為空
const CHECK_EMAIL_NOTNULL = (rule, value, callback) => {
let check = this.$validate({label: '郵箱', value, rules: ['notnull', 'email']})
if (!check.result) {
callback(new Error(check.message))
} else {
callback()
}
}
return {
CHECK_PHONE,
CHECK_PHONE_NOTNULL,
CHECK_EMAIL,
CHECK_EMAIL_NOTNULL
}
},
methods: {
// 初始化驗證數(shù)據(jù)
_initValidate (formInfo) {
const obj = {},
fieldList = formInfo.fieldList
// 循環(huán)字段列表
for (let item of fieldList) {
let type = item.type === 'select' ? '選擇' : '輸入'
if (item.required) {
if (item.validator) {
obj[item.value] = {
required: item.required,
validator: item.validator,
trigger: 'blur'
}
} else {
obj[item.value] = {
required: item.required,
message: '請' + type + item.label,
trigger: 'blur'
}
}
} else if (item.validator) {
obj[item.value] = {
validator: item.validator,
trigger: 'blur'
}
}
}
formInfo.rules = obj
}
}
}
最后
在項目的系統(tǒng)管理模塊中可以看到示例代碼:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
前端Vue3項目打包成Docker鏡像運行的詳細(xì)步驟
將Vue3項目打包、編寫Dockerfile、構(gòu)建Docker鏡像和運行容器是部署Vue3項目到Docker的主要步驟,這篇文章主要介紹了前端Vue3項目打包成Docker鏡像運行的詳細(xì)步驟,需要的朋友可以參考下2024-09-09
Vue input控件通過value綁定動態(tài)屬性及修飾符的方法
這篇文章主要介紹了 Vue input控件通過value綁定動態(tài)屬性及修飾符的方法,需要的朋友可以參考下2017-05-05
在vue中獲取微信支付code及code被占用問題的解決方法
這篇文章主要介紹了在vue中獲取微信支付code及code被占用問題的解決方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-04-04

