vue 使用自定義指令實現(xiàn)表單校驗的方法
筆者近期在公司的項目中使用自定義指令完成了表單校驗。
這里將思路分享給大家,并寫了一個小demo。這個自定義指令還需要大家自行完善。
demo可見Github:vue-form-param-check
首先關(guān)于自定義指令的介紹可以參考官網(wǎng)。
首先,在github上已經(jīng)有了一些開源組件可以支持表單校驗。但是對于一些小項目而言,引入一個很大的東西實際上并不好。所以這里利用vue的自定義指令對表單校驗進行了簡單的實現(xiàn)。
分析
在平時我們所見的表單中,常見的做法有2種:
- input框輸入時和提交時,立馬進行校驗;
- 提交時,統(tǒng)一校驗。
針對這2種實現(xiàn),筆者分別進行了實現(xiàn)。分別如下。
input框輸入和提交時,進行校驗
import Vue from 'vue'
const IP_REGEX = '^(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|[1-9])\\.' +
'(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)\\.' +
'(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)\\.' +
'(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)$'
// 注冊一個全局自定義指令 `v-checkParam`
Vue.directive('checkParam', {
// 當被綁定的元素插入到 DOM 中時……
inserted: function (el, binding, vNode) {
el.addEventListener('keyup', function (event) {
// 首先去除已有樣式
el.className = el.className.replace('input-error', '').trim()
// if (!event.keyCode) { // 加上這個判斷就是在提交時,才會校驗
// 判斷是否是否必填
let isRequired = binding.value.required
if (isRequired) {
if (!el.value || el.value === '') {
el.className += ' input-error'
}
}
// 判斷正則
// debugger
let regex = binding.value.regex
if (regex === 'IpRegex') {
if (!el.value.match(IP_REGEX)) {
el.className += ' input-error'
}
} else if (!el.value.match(regex)) {
el.className += ' input-error'
}
// }
})
}
})
// 注冊一個全局自定義指令 `v-checkSubmit`
Vue.directive('checkSubmit', {
// 當被綁定的元素插入到 DOM 中時……
inserted: function (el, binding, vNode) {
el.addEventListener('click', function (event) {
let elements = document.getElementsByClassName('v-check')
var evObj = document.createEvent('Event')
evObj.initEvent('keyup', true, true)
for (let element of elements) {
element.dispatchEvent(evObj)
}
let errorInputs = document.getElementsByClassName('input-error');
if(errorInputs.length === 0){
vNode.context.submit();
}
})
}
})
提交時,再統(tǒng)一校驗
import Vue from 'vue'
const IP_REGEX = '^(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|[1-9])\\.' +
'(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)\\.' +
'(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)\\.' +
'(1\\d{2}|2[0-4]\\d|25[0-5]|[1-9]\\d|\\d)$'
// 注冊一個全局自定義指令 `v-checkParam`
Vue.directive('checkParam', {
// 當被綁定的元素插入到 DOM 中時……
inserted: function (el, binding, vNode) {
el.addEventListener('keyup', function (event) {
// 首先去除已有樣式
el.className = el.className.replace('input-error', '').trim()
if (!event.keyCode) { // 加上這個判斷就是在提交時,才會校驗
// 判斷是否是否必填
let isRequired = binding.value.required
if (isRequired) {
if (!el.value || el.value === '') {
el.className += ' input-error'
}
}
// 判斷正則
let regex = binding.value.regex
if (regex === 'IpRegex') {
if (!el.value.match(IP_REGEX)) {
el.className += ' input-error'
}
}
else if (!el.value.match(regex)) {
el.className += ' input-error'
}
}
})
}
})
// 注冊一個全局自定義指令 `v-checkSubmit`
Vue.directive('checkSubmit', {
// 當被綁定的元素插入到 DOM 中時……
inserted: function (el, binding, vNode) {
el.addEventListener('click', function (event) {
let elements = document.getElementsByClassName('v-check')
var evObj = document.createEvent('Event')
evObj.initEvent('keyup', true, true)
for (let element of elements) {
element.dispatchEvent(evObj)
}
let errorInputs = document.getElementsByClassName('input-error');
if(errorInputs.length === 0){
vNode.context.submit();
}
})
}
})
區(qū)別
其實大家很容易發(fā)現(xiàn),上面的2種實現(xiàn)只有一個if的區(qū)別,這個的含義是:由提交按鈕觸發(fā)的keyup,是沒有keycode的,所以在if(!event.keyCode)滿足時,進行校驗(也就是在僅提交時,進行校驗)。
用法說明
下面給出用例。
<template>
<div>
<div>
<label class="star">Name:</label>
<input class='v-check' v-checkParam="{required:true,regex:'^[abcde]*$'}" type="text">
</div>
<div>
<label class="star">IP:</label>
<input class='v-check' v-checkParam="{required:true,regex:'IpRegex'}"
type="text">
</div>
<div>
<button v-checkSubmit>提交</button>
</div>
</div>
</template>
<script>
export default {
name: 'demo',
methods: {
submit () {
alert('通過校驗')
}
}
}
</script>
<style scoped>
input{
height: 22px;
}
.input-error{
background-color: red;
}
.star:before
{
content:"*";
color:red;
}
</style>
所有綁定了class=”v-check”的input,都會在v-checkSubmit被click時進行校驗,而其校驗規(guī)則是v-checkParam對應的規(guī)則。
全部校驗通過后,會回調(diào)到submit方法。進行觸發(fā)接下來的事務。
效果截圖


以上這篇vue 使用自定義指令實現(xiàn)表單校驗的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解如何使用vue和electron開發(fā)一個桌面應用
這篇文章主要為大家介紹了詳解如何使用vue和electron開發(fā)一個桌面應用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03
vue項目中v-model父子組件通信的實現(xiàn)詳解
vue.js,是一個構(gòu)建數(shù)據(jù)驅(qū)動的 web 界面的庫。Vue.js 的目標是通過盡可能簡單的 API 實現(xiàn)響應的數(shù)據(jù)綁定和組合的視圖組件。下面這篇文章主要給大家介紹了關(guān)于vue項目中v-model父子組件通信實現(xiàn)的相關(guān)資料,需要的朋友可以參考下。2017-12-12
基于vue-cli 打包時抽離項目相關(guān)配置文件詳解
下面小編就為大家分享一篇基于vue-cli 打包時抽離項目相關(guān)配置文件詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
vue 實現(xiàn)element-ui中的加載中狀態(tài)
這篇文章主要介紹了vue 實現(xiàn)element-ui中的加載中狀態(tài),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
Vue-drag-resize 拖拽縮放插件的使用(簡單示例)
本文通過代碼給大家介紹了Vue-drag-resize 拖拽縮放插件使用簡單示例,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12

