亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

vue 使用自定義指令實現表單校驗的方法

2019-11-19 13:07:45
字體:
來源:轉載
供稿:網友

筆者近期在公司的項目中使用自定義指令完成了表單校驗。

這里將思路分享給大家,并寫了一個小demo。這個自定義指令還需要大家自行完善。

demo可見Github:vue-form-param-check

首先關于自定義指令的介紹可以參考官網。

首先,在github上已經有了一些開源組件可以支持表單校驗。但是對于一些小項目而言,引入一個很大的東西實際上并不好。所以這里利用vue的自定義指令對表單校驗進行了簡單的實現。

分析

在平時我們所見的表單中,常見的做法有2種:

- input框輸入時和提交時,立馬進行校驗;

- 提交時,統一校驗。

針對這2種實現,筆者分別進行了實現。分別如下。

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();   }  }) }})

提交時,再統一校驗

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();   }  }) }})

區別

其實大家很容易發現,上面的2種實現只有一個if的區別,這個的含義是:由提交按鈕觸發的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時進行校驗,而其校驗規則是v-checkParam對應的規則。

全部校驗通過后,會回調到submit方法。進行觸發接下來的事務。

效果截圖

以上這篇vue 使用自定義指令實現表單校驗的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一区第二区| 亚洲国产三级网| 久久全球大尺度高清视频| 久久人人爽国产| 欧美一级高清免费| 美女精品久久久| 欧美视频第一页| 精品视频在线导航| 成人精品福利视频| 国产区亚洲区欧美区| 91免费高清视频| 亚洲国产精品嫩草影院久久| 亚洲精品小视频在线观看| 97精品一区二区视频在线观看| 欧美日韩第一视频| 日韩av一区二区在线| 日本国产一区二区三区| 欧美黑人巨大精品一区二区| 国产在线视频2019最新视频| 亚洲一区二区三区毛片| 亚洲www永久成人夜色| 久久久人成影片一区二区三区观看| 亚洲黄在线观看| 国产精品高清在线| 精品欧美aⅴ在线网站| 日韩av影视综合网| 日韩精品中文字幕在线| 国产一区二区在线免费| 亚洲精品成人av| 日韩国产精品亚洲а∨天堂免| 精品国产91久久久久久| 福利精品视频在线| 久久久久久久久91| 91久久久国产精品| 亚洲美腿欧美激情另类| 国产亚洲a∨片在线观看| 精品久久久一区二区| 九色精品美女在线| 亚洲日本aⅴ片在线观看香蕉| 黄色成人av在线| 久久久久久久久网站| 亚洲国产成人精品一区二区| 精品少妇一区二区30p| 黄色一区二区在线| 亚洲国产精品系列| 92裸体在线视频网站| 久久免费视频在线观看| 日韩欧美在线网址| 欧美午夜无遮挡| 久久艹在线视频| 国产精品免费久久久久影院| 久久久女女女女999久久| 亚洲天堂av在线免费| 亚洲天堂免费观看| 午夜精品一区二区三区在线视| 久久艳片www.17c.com| 国产精品视频自拍| 26uuu另类亚洲欧美日本老年| 91精品国产高清自在线看超| 欧美乱大交xxxxx另类电影| 亚洲国产精品人久久电影| 一区二区三区视频免费在线观看| 欧美精品在线播放| 欧美视频一区二区三区…| 精品视频在线播放| 亚洲人成电影在线| 一区二区三区无码高清视频| 亚洲影院在线看| 国语自产精品视频在免费| 欧美中文在线观看国产| 欧美大片大片在线播放| 亚洲香蕉av在线一区二区三区| 国产亚洲人成a一在线v站| 最近2019年中文视频免费在线观看| 国产精品视频区1| 精品欧美一区二区三区| 精品美女久久久久久免费| 亚洲综合日韩中文字幕v在线| 成人在线一区二区| 精品久久久久久亚洲精品| 久久电影一区二区| 久久99热精品这里久久精品| 欧美国产视频日韩| 欧美在线视频免费| 中文精品99久久国产香蕉| 久久精品中文字幕电影| 国产精品欧美激情| 亚洲精品理论电影| 亚洲男人天堂久| 91av视频在线| 亚洲男子天堂网| 日韩一中文字幕| 91在线精品视频| 中文字幕亚洲精品| 日韩在线观看免费| 亚洲国产另类 国产精品国产免费| 日韩精品极品在线观看播放免费视频| 欧美最顶级的aⅴ艳星| 久国内精品在线| 欧美性69xxxx肥| 国产精品一区二区三区毛片淫片| 91精品国产综合久久久久久蜜臀| 欧美成人免费视频| 大胆人体色综合| 精品国产1区2区| 欧美激情在线播放| 亚洲成**性毛茸茸| 亚洲aⅴ男人的天堂在线观看| 日韩国产在线播放| 国产精品视频大全| 国产成人精品一区二区在线| 国产精品视频区| 全色精品综合影院| 精品女同一区二区三区在线播放| 亚洲r级在线观看| 欧美色欧美亚洲高清在线视频| 91人成网站www| 国产成人精品在线视频| 国产精品视频网站| 97在线视频免费播放| 奇米4444一区二区三区| 日韩欧美国产激情| 中文字幕亚洲欧美日韩高清| 国产欧美亚洲精品| 欧美日本高清视频| 色悠久久久久综合先锋影音下载| 国产精品综合网站| 久久69精品久久久久久国产越南| 成人www视频在线观看| 精品久久久久久国产| 欧美性高跟鞋xxxxhd| 久久精品视频亚洲| 色婷婷综合成人| 狠狠色香婷婷久久亚洲精品| 色噜噜狠狠色综合网图区| 欧美日韩视频在线| 日韩精品一区二区三区第95| 久久久999精品| 亚洲人成电影网站色www| 91av在线免费观看| 精品视频在线播放色网色视频| 最近2019中文字幕大全第二页| 91久久国产精品| 中文字幕av日韩| 欧美在线影院在线视频| 亚洲肉体裸体xxxx137| 久久视频在线免费观看| 日本电影亚洲天堂| 高清日韩电视剧大全免费播放在线观看| 亚洲欧美国产制服动漫| 欧美激情视频给我| 亚洲男人天天操| 激情亚洲一区二区三区四区| 亚洲欧美国产制服动漫| 亚洲天堂av在线播放| 国产精品高清在线| 日韩精品中文字幕久久臀| 欧美一区二区三区精品电影| 91夜夜揉人人捏人人添红杏| 青青在线视频一区二区三区| 欧美午夜精品久久久久久人妖| 欧美高清在线播放| 久久天天躁狠狠躁夜夜爽蜜月| 一本大道亚洲视频|