欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

自帶氣泡提示的vue校驗插件(vue-verify-pop)

 更新時間:2017年04月07日 11:28:19   作者:余阿偉  
這篇文章主要為大家詳細介紹了自帶氣泡提示的vue校驗插件,vue-verify-pop的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本教程大家分享了自帶氣泡提示的vue校驗插件,供大家參考,具體內(nèi)容如下

安裝

npm install vue-verify-pop

使用

VUE版本:1.x
必須在vue-cli生成的webpack模板環(huán)境中使用

一、在./main.js中執(zhí)行全局配置

import vue from 'vue'
import verify from 'vue-verify-pop'
vue.use(verify)
// 以下配置非必須,按你的需求來
// 配置默認校驗不通過時的提示信息
verify.errMsg = YourErroMsg
// 增加校驗規(guī)則
verify.addRule('myRule', (v) => {return '校驗不通過'})

二、在表單元素中配置校驗規(guī)則

<!--待校驗元素的pop容器-->
<pop>
 <!--該輸入框內(nèi)容為最多為兩位小數(shù)的數(shù)字-->
 <input v-verify decimal-length="2">
</pop>

ok,您已經(jīng)完成了一個基礎(chǔ)校驗。氣泡提示怎么樣?丑的話自己用css改吧。。
當(dāng)輸入框失去焦點時會自動觸發(fā)校驗,如果校驗不通過會出現(xiàn)氣泡。再次輸入氣泡會消失

支持的校驗規(guī)則(繼承verify-base.js)

  • length: 校驗文本長度
  • minLength: 校驗文本最短長度
  • maxLength: 校驗文本最長長度
  • maxNumber: 校驗數(shù)字最大值
  • minNumber: 校驗數(shù)字最小值
  • decimalLength: 校驗小數(shù)位
  • number: 校驗是否為數(shù)字
  • int: 校驗是否為整數(shù)
  • phone: 校驗是否為手機號
  • idCard: 校驗是否為身份證號
  • bankCard: 校驗是否為銀行卡號
  • email: 校驗是否為電子郵件地址
  • verifyCode: 校驗是否為6位數(shù)字驗證碼
  • canBeNull: 當(dāng)參數(shù)為空時跳過校驗,不會執(zhí)行后面的校驗規(guī)則(注意:自定義校驗函數(shù)'verify'仍然會執(zhí)行)

重要參數(shù)說明

注意:規(guī)則中不能有大寫字母,用中劃線分隔,同vue props屬性設(shè)置規(guī)則

errMsg

用于自定義校驗不通過提示

<pop>
 <input v-verify length="10" err-msg="請輸入正確的卡號">
</pop>

maxNumber

注意小于和小于等于的寫法

<!--該輸入框內(nèi)容必須為小于等于10的數(shù)字-->
<pop>
 <input v-verify max-number="10">
</pop>
<!--該輸入框內(nèi)容必須為小于10的數(shù)字,通過'!'來標識-->
<pop>
 <input v-verify max-number="!10">
</pop>

minNumber

參考maxNumber配置

pop

用于設(shè)置氣泡組件的位置。
默認情況下,插件會查找待校驗元素的分發(fā)對象或父容器(父容器的父容器的父容器...)是否為pop組件,如果找到則使用之。
當(dāng)待校驗元素和氣泡提示不再滿足父子容器關(guān)系時,可以用如下方式去指定:

<!--當(dāng)校驗不通過時,氣泡提示會出現(xiàn)在這個div上面-->
<pop id="cardIdPop">
  <div>我是一個div</div>
</pop>
<input v-verify length="10" err-msg="卡號不正確" pop="cardIdPop">

noCache

用于禁止插件對校驗結(jié)果的緩存。默認情況下,插件會緩存上次的校驗結(jié)果,直到待校驗元素的值發(fā)生變化

<pop>
 <input v-verify length="10" err-msg="卡號不正確" no-cache>
</pop>

canBeNull

插件默認校驗輸入內(nèi)容不為空,該參數(shù)一般用于如下情況,比如邀請碼這種一般可以為空,不為空又需要校驗的輸入項

自定義校驗方法verify始終會執(zhí)行,主要考慮到該校驗方法中的校驗對象很可能不僅僅是輸入框本身的值,故不應(yīng)受該配置項的影響

<!--當(dāng)邀請碼不為空時才校驗長度是否等于10-->
<pop>
 <input v-verify length="10" err-msg="邀請碼不正確" can-be-null>
</pop>

watch

監(jiān)聽其他變量,觸發(fā)自身校驗。
一個常見例子:最少參與人數(shù)不能大于最多參與人數(shù),當(dāng)最少參與人數(shù)變化時應(yīng)當(dāng)觸發(fā)最多參與人數(shù)的校驗

<template>
 <pop>
  <input placeholder="最少參與人數(shù)" v-verify v-model="minNumber" v-verify int>
 </pop>
 <pop>
  <input placeholder="最多參與人數(shù)" v-verify v-model="minNumber" v-verify int :verify="verifyMaxNumber" :watch="minNumber">
 </pop>
</template>
<script>
export default{
 data () {
  return {
   minNumber: ''
  }
 },
 methods: {
  verifyMaxNumber (val) {
   if (val - this.minNumber < 0) return '最多參與人數(shù)不能小于最少參與人數(shù)'
  }
 }
}
</script>

規(guī)則簡寫

number/int/phone等無須設(shè)定值的規(guī)則可以直接:

<pop>
 <!--該輸入框內(nèi)容必須為手機號-->
 <input v-verify phone>
</pop>

maxNumber/minNumber/decimalLength無須寫number規(guī)則

<pop>
 <!--該輸入框內(nèi)容必須為不大于10的數(shù)字-->
 <input v-verify max-number="10">
 <!--不用這么寫-->
 <input v-verify number max-number="10">
</pop>

自定義校驗方法

如果自帶的校驗方法滿足不了您的需求,可以在校驗規(guī)則中插入您自己的校驗方法

<template>
 <pop>
  <!--通過給props.verify賦值來植入自定義校驗-->
  <!--當(dāng)length規(guī)則通過時才會執(zhí)行自定義校驗-->
  <input v-verify length="10" :verify="verifyCardId" err-msg="卡號不正確">
 </pop>
</template>
<script>
export default{
 methods: {
  verifyCardId (val) {
   // val: 待校驗的值
   // 可以直接return校驗不通過的提示
   // if (val.substr(0,1) !== '0') return '卡號不正確'
   // 如果直接return true/false 校驗不通過提示將使用errMsg或默認錯誤提示
   // return val.substr(0,1) === '0'
  }
 }
}
</script>

自定義校驗規(guī)則

和自定義校驗方法的區(qū)別是這個適用于全局,等于增加插件自帶的校驗規(guī)則

// 新增校驗是否為6位數(shù)字 val: 待校驗的值 rule: 規(guī)則值。
// 校驗是否為6位數(shù)字這種一般時不需要額外參數(shù)用來對比,所以rule參數(shù)用不到。校驗文本長度,數(shù)字大小這種才會用到rule
// <input v-verify length="6"> '6'會作為rule參數(shù)
var verifyBase = verify.verifyBase
verify.addRule('number6', (val, rule) => {
 // 判斷是否為6位數(shù)字
 // 只需要關(guān)注錯誤的情況 返回默認出錯提示即可
 if (!verifyBase('number')(val).valid || !verifyBase('length')(val, 6)) return '請輸入正確的6位數(shù)字'
})

調(diào)用

<!--校驗不通過提示優(yōu)先errMsg,然后才是您自定義規(guī)則中返回的默認出錯提示-->
<input v-verify number6 err-msg="請輸入正確的6位數(shù)字驗證碼">

手動觸發(fā)校驗&分組校驗

<template>
 <pop>
  <!--給目標元素設(shè)置v-el-->
  <input v-verify length="10" err-msg="卡號1不正確" v-el:ipt>
 </pop>
 <pop>
  <!--給目標元素設(shè)置id-->
  <input v-verify length="10" err-msg="卡號2不正確" id="ipt">
 </pop>
 <!--給目標元素設(shè)置組名-->
 <verify name="verifyGroup">
  <pop>
   <input v-verify length="10" err-msg="卡號3不正確">
  </pop>
  <pop>
   <input v-verify length="10" err-msg="卡號4不正確">
  </pop>
 </verify>
</template>
<script>
export default{
 ready () {
  // 調(diào)用vm對象中$verify方法
  // 無參調(diào)用會觸發(fā)當(dāng)前vm中所有的待校驗元素執(zhí)行校驗并顯示校驗氣泡
  this.$verify()
  // 通過傳id參數(shù)('#'+id)觸發(fā)輸入框的校驗并顯示校驗氣泡
  this.$verify('#ipt')
  // 通過傳dom元素觸發(fā)輸入框的校驗并顯示校驗氣泡
  this.$verify(this.$els.ipt)
  // 通過傳校驗組名來校驗該組的所有待校驗元素
  this.$verify('verifyGroup')
  // 只校驗,不顯示校驗氣泡
  this.$verify('verifyGroup', false)
  // 返回:
  {
   // 所有校驗結(jié)果是否都通過
   valid: true/false,
   results: [
    {
     // 校驗的dom元素
     el: DOM,
     // 該元素校驗是否通過
     valid: true/false,
     // 錯誤信息
     msg: ''
    }
   ]
  }
 }
}
</script>

插件的默認校驗不通過提示模版

{
 number: {
  common: '請輸入數(shù)字',
  // >
  maxNumber: '該輸入框數(shù)字不能大于{maxNumber}',
  // >=
  maxNumber2: '該輸入框數(shù)字應(yīng)小于{maxNumber}',
  // <
  minNumber: '該輸入框數(shù)字不能小于{minNumber}',
  // <=
  minNumber2: '該輸入框數(shù)字應(yīng)大于{minNumber}',
  decimalLength: '該輸入框最多接受{decimalLength}位小數(shù)'
 },
 // 特殊類型
 int: '該輸入框僅接受整數(shù)',
 phone: '請輸入正確的手機號',
 idCard: '請輸入正確的身份證號',
 bankCard: '請輸入正確的銀行卡號',
 email: '請輸入正確的郵箱',
 verifyCode: '請輸入正確的驗證碼',
 common: {
  empty: '請補充該項內(nèi)容',
  length: '請輸入{length}位字符',
  minLength: '該輸入框內(nèi)容至少{minLength}位'
 },
 specialInput: {
  checkbox: '請勾選我'
 }
}

您可以按照上述格式自定義您的錯誤提示

verify.errMsg = {}

也可以只修改某些項

verify.errMsg.int = '{mark}必須為整數(shù)'

彩蛋

校驗插件不僅能檢測到輸入內(nèi)容的變化,綁定值的變化同樣在掌控之內(nèi),也就是說校驗氣泡的出現(xiàn)和消失您完全無須手動控制

<!--當(dāng)卡號輸入框出校驗氣泡提示時,cardId值的變化或重新輸入卡號,氣泡提示都會消失-->
<pop>
 <input v-model="cardId" v-verify length="10" err-msg="卡號不正確">
</pop>

verifyBase

本插件校驗的核心方法來自verify-base

// 通過該方式獲取verifyBase以使用其內(nèi)置的各種校驗方法
verify.verifyBase

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 對Vue3中reactive的深入理解

    對Vue3中reactive的深入理解

    這篇文章主要介紹了對Vue3中reactive的深入理解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue之el-select結(jié)合v-if動態(tài)控制template顯示隱藏方式

    Vue之el-select結(jié)合v-if動態(tài)控制template顯示隱藏方式

    這篇文章主要介紹了Vue之el-select結(jié)合v-if動態(tài)控制template顯示隱藏方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 淺談Vue3的幾個優(yōu)勢

    淺談Vue3的幾個優(yōu)勢

    這篇文章主要給大家分享的是Vue3的幾個優(yōu)勢,Vue3仍然在源碼、性能和語法 API 三個大的方面進行了優(yōu)化,下面我們一起進入文章看看具體詳情吧
    2021-10-10
  • vue使用html2canvas實現(xiàn)將DOM節(jié)點生成對應(yīng)的PDF

    vue使用html2canvas實現(xiàn)將DOM節(jié)點生成對應(yīng)的PDF

    這篇文章主要為大家詳細介紹了vue如何使用html2canvas實現(xiàn)將DOM節(jié)點生成對應(yīng)的PDF,文中的示例代碼簡潔易懂,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-08-08
  • vue+element ui實現(xiàn)錨點定位

    vue+element ui實現(xiàn)錨點定位

    這篇文章主要為大家詳細介紹了vue+element ui實現(xiàn)錨點定位,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Vue 框架之鍵盤事件、健值修飾符、雙向數(shù)據(jù)綁定

    Vue 框架之鍵盤事件、健值修飾符、雙向數(shù)據(jù)綁定

    這篇文章主要介紹了Vue 框架之鍵盤事件、健值修飾符、雙向數(shù)據(jù)綁定問題,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • Vue數(shù)據(jù)驅(qū)動表單渲染,輕松搞定form表單

    Vue數(shù)據(jù)驅(qū)動表單渲染,輕松搞定form表單

    這篇文章主要介紹了Vue數(shù)據(jù)驅(qū)動表單渲染,輕松搞定form表單,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • vue前后端端口不一致的問題解決

    vue前后端端口不一致的問題解決

    本文主要介紹了vue前后端端口不一致的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-10-10
  • vue2.x select2 指令封裝詳解

    vue2.x select2 指令封裝詳解

    本篇文章主要介紹了vue2.x select2 指令封裝詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 詳解Vue CLI3配置之filenameHashing使用和源碼設(shè)計使用和源碼設(shè)計

    詳解Vue CLI3配置之filenameHashing使用和源碼設(shè)計使用和源碼設(shè)計

    這篇文章主要介紹了詳解Vue CLI3配置之filenameHashing使用和源碼設(shè)計使用和源碼設(shè)計,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08

最新評論