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

詳解vuelidate 對(duì)于vueJs2.0的驗(yàn)證解決方案

 更新時(shí)間:2017年03月09日 10:48:48   作者:JellyBean  
本篇文章主要介紹了vuelidate 對(duì)于vueJs2.0的驗(yàn)證解決方案,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。

介紹

在后端項(xiàng)目里 比如我們的Laravel框架 對(duì)于表單驗(yàn)證有自己的一套validation機(jī)制 他將驗(yàn)證集成在FormRequest

我們只需要在我們的方法中依賴注入我們自己實(shí)例化后的驗(yàn)證類 當(dāng)然也可以直接去在方法里去驗(yàn)證表單數(shù)據(jù)

而在我們的前端的項(xiàng)目里 也就是在我們的vue項(xiàng)目里 也有比較好的驗(yàn)證解決方案 也就是這的vuelidate

1.安裝

和我們安裝前端包一樣 在項(xiàng)目終端執(zhí)行:

$ npm install vuelidate --save

安裝完成后和我們?nèi)ナ褂胿uex一樣 在main.js去引入聲明這個(gè)package:

import Vue from 'vue'
import Vuelidate from 'vuelidate'
Vue.use(Vuelidate)

當(dāng)然你也可以在需要用到驗(yàn)證的組件里去引用一個(gè)相對(duì)小的版本:

import { validationMixin } from 'vuelidate'

var Component = Vue.extend({
 mixins: [validationMixin],
 validation: { ... }
})

如果你偏好通過require這樣的形式 你也可以這樣引入:

const { validationMixin, default: Vuelidate } = require('vuelidate')
const { required, minLength } = require('vuelidate/lib/validators')

2.使用

其實(shí)使用起來真的很方便 下面舉例來說就是在我的項(xiàng)目里的使用

1.注冊(cè)驗(yàn)證

在用戶注冊(cè)時(shí) 我們通常的需要處理的表單字段就是name,email,password,confirm_pwd

首先我在Register.vue這個(gè)組件文件中把基本的樣式結(jié)構(gòu)寫好 這取決于每個(gè)人

接著是我們對(duì)表單數(shù)據(jù)的驗(yàn)證:

這里是對(duì)用戶名和郵箱的驗(yàn)證 就像之前提到的 我們先引入我們的驗(yàn)證規(guī)則:

import { required,minLength,between,email } from 'vuelidate/lib/validators'

因?yàn)槲沂菍?duì)一個(gè)新用戶的注冊(cè) 所以我定義一個(gè)data

 data(){
  return{
    newUser: {
      name:'',
      email:'',
      password:'',
      confirm_pwd:''
    },
  }
},

接著去定義我們的驗(yàn)證字段的規(guī)則:

validations: {
  newUser:{
    name: {
      required,
      minLength: minLength(2)
    },
    email: {
      required,email
    }
  }
},

定義這些驗(yàn)證規(guī)則之后 下面是我的html部分內(nèi)容

<div class="control-group" v-bind:class="{ 'form-group--error': $v.newUser.name.$error }">
<label class="control-label">用戶名</label>
<el-input
    placeholder="請(qǐng)輸入你的用戶名"
    v-model.trim="newUser.name"
    @input="$v.newUser.name.$touch()"
>
</el-input>
</div>
<span class="form-group__message" v-if="!$v.newUser.name.required">用戶名不能為空</span>
<span class="form-group__message" v-if="!$v.newUser.name.minLength">用戶名不能太短</span>

<div class="control-group" v-bind:class="{ 'form-group--error': $v.newUser.email.$error }">
<label class="control-label">郵箱</label>
<el-input
    placeholder="請(qǐng)輸入你的郵箱"
    v-model.trim="newUser.email"
    @input="$v.newUser.email.$touch()"
>
</el-input>
</div>
<span class="form-group__message" v-if="!$v.newUser.email.required">郵箱不能為空</span>
<span class="form-group__message" v-if="!$v.newUser.email.email">請(qǐng)?zhí)顚懻_的郵箱格式</span>

每個(gè)人可以都不一樣 官方文檔上也給出了demo:

<div>
 <div class="form-group" v-bind:class="{ 'form-group--error': $v.flatA.$error }">
  <label class="form__label">Flat A</label>
  <input class="form__input" v-model.trim="flatA" @input="$v.flatA.$touch()">
 </div><span class="form-group__message" v-if="!$v.flatA.required">Field is required.</span>
 <div class="form-group" v-bind:class="{ 'form-group--error': $v.flatB.$error }">
  <label class="form__label">Flat B</label>
  <input class="form__input" v-model.trim="flatB" @input="$v.flatB.$touch()">
 </div><span class="form-group__message" v-if="!$v.flatB.required">Field is required.</span>
 <div class="form-group" v-bind:class="{ 'form-group--error': $v.forGroup.nested.$error }">
  <label class="form__label">Nested field</label>
  <input class="form__input" v-model.trim="forGroup.nested" @input="$v.forGroup.nested.$touch()">
 </div><span class="form-group__message" v-if="!$v.forGroup.nested.required">Field is required.</span>
 <div class="form-group" v-bind:class="{ 'form-group--error': $v.validationGroup.$error }"></div><span class="form-group__message" v-if="$v.validationGroup.$error">Group is invalid.</span>
 <pre>validationGroup: {{ $v.validationGroup }}</pre>
</div>

我們先這樣舉例 值得注意的是我們需要去知道他的$v.name里面的內(nèi)容

也就是 $invalid $dirty $error $pending $each 這個(gè)value

特別的注意 $error里的解釋:It is a shorthand to $invalid && $dirty

也就是一個(gè)與的組合 你可以去試著改變這兩者的值 再去看$error的值

當(dāng)然還有兩個(gè)重要的方法: $touch $reset 上面也有實(shí)例 說簡單點(diǎn)就是設(shè)置這個(gè)以及子節(jié)點(diǎn)的$dirty 為true或者false

而設(shè)置這個(gè)$dirty 再結(jié)合 $invalid就可以判斷驗(yàn)證成功與否

$error 是由$dirty和$invalid共同決定的

在這里的驗(yàn)證規(guī)則流程是這樣的 如果$error為true那么form-group會(huì)添加一個(gè)form-group--error這個(gè)class

只有在$error為true時(shí) 如果你不符合任意一個(gè)驗(yàn)證規(guī)則 例如不符合required 那么就會(huì)提示驗(yàn)證失敗

如果驗(yàn)證錯(cuò)誤就給出錯(cuò)誤提示 這是我的錯(cuò)誤樣式:

.form-group__message{
  display: none;
  font-size: .95rem;
  color: #CC3333;
  margin-left: 10em;
  margin-bottom: 12px;
}
.form-group--error+.form-group__message {
  display: block;
  color: #CC3333;
}

.form-group--error input, .form-group--error input:focus, .form-group--error input:hover, .form-group--error textarea {
  border-color: #CC3333;
}

2.密碼驗(yàn)證

密碼驗(yàn)證其實(shí)和上面的差不多 只不過他的驗(yàn)證規(guī)則時(shí)通過 sameAs 來進(jìn)行驗(yàn)證的

3.組合驗(yàn)證

除了上面這些還有一個(gè)組合驗(yàn)證 也就是如果任意一個(gè)不符合驗(yàn)證規(guī)則就不通過 這個(gè)還是挺常用的

我們可以在驗(yàn)證字段這樣去組合:

validations: {
  flatA: { required },
  flatB: { required },
  forGroup: {
   nested: { required }
  },
  validationGroup: ['flatA', 'flatB', 'forGroup.nested']
}

如果任意一個(gè)就是FlatA flatB forGroup其中一個(gè)不符合驗(yàn)證規(guī)則 那么$v.validationGroup.$error就是false

4.異步驗(yàn)證

特別是在驗(yàn)證唯一性的時(shí)候 我們肯定會(huì)遇到這樣的一個(gè)場景:

就比如我們的郵箱 如果已經(jīng)注冊(cè)過這個(gè)郵箱了 那么再用這個(gè)郵箱去注冊(cè)顯然不是我們想要的

還有就是我們登錄時(shí)我們需要去核對(duì)我們的用戶的密碼

這邊我給出的實(shí)例就是對(duì)于用戶名的注冊(cè) 如果已經(jīng)注冊(cè)了就會(huì)提示已經(jīng)注冊(cè)過

完全支持async/await語法。它與Fetch API結(jié)合使用也很出色 那么我們可以通過后端API提供的結(jié)果可以進(jìn)行判斷
我們可以去增加我們唯一性的驗(yàn)證:

name: {
  required,
  minLength: minLength(4),
  async isUnique (value) {
    if (value === '') return true
    const response = await fetch(`http://localhost:8000/api/unique/name/${value}`)
    return Boolean(await response.json())
  }
},

這里我現(xiàn)在本地測試 通過Laravel作為后端來提供的數(shù)據(jù)校驗(yàn) 實(shí)際項(xiàng)目中的話可以再結(jié)合數(shù)據(jù)庫

//用戶驗(yàn)證路由
Route::group(['prefix'=>'unique','middleware'=>['api','cors']], function () {
  Route::get('/name/{value}',function(Request $request,$value){
    if($value==="gavin"){
      return response()->json(false);
    }
    return response()->json(true);
  });
});

如果我們?nèi)プ?cè) gavin這個(gè)用戶就會(huì)提示該昵稱已經(jīng)被注冊(cè) 因?yàn)樵谟脩裘以黾恿薸sUnique驗(yàn)證

復(fù)制代碼 代碼如下:

<span class="form-group__message" v-if="!$v.newUser.name.isUnique">用戶名已經(jīng)被注冊(cè)</span>

顯示結(jié)果應(yīng)該是這樣的:

5.自定義驗(yàn)證

同樣的我們不僅可以使用它提供給我們的驗(yàn)證規(guī)則 我們也可以自定義驗(yàn)證規(guī)則并與之前的進(jìn)行組合

官方給出了一個(gè)簡單實(shí)例:

export default value => {
 if (Array.isArray(value)) return !!value.length

 return value === undefined || value === null
  ? false
  : !!String(value).length
}

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

相關(guān)文章

  • 如何在vue項(xiàng)目中使用UEditor--plus

    如何在vue項(xiàng)目中使用UEditor--plus

    UEditor是由百度web前端研發(fā)部開發(fā)的所見即所得的開源富文本編輯器,這篇文章主要介紹了如何在vue項(xiàng)目中使用UEditor--plus?,需要的朋友可以參考下
    2022-08-08
  • vite2打包的時(shí)候vendor-xxx.js文件過大的解決方法

    vite2打包的時(shí)候vendor-xxx.js文件過大的解決方法

    vite2是一個(gè)非常好用的工具,只是隨著代碼的增多,打包的時(shí)候?vendor-xxxxxx.js?文件也越來越大,本文主要介紹了vite2打包的時(shí)候vendor-xxx.js文件過大的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue生命周期與鉤子函數(shù)簡單示例

    vue生命周期與鉤子函數(shù)簡單示例

    這篇文章主要介紹了vue生命周期與鉤子函數(shù),結(jié)合簡單實(shí)例形式分析了vue.js生命周期及鉤子函數(shù)相關(guān)流程與實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-03-03
  • Vue入門學(xué)習(xí)筆記【基本概念、對(duì)象、過濾器、指令等】

    Vue入門學(xué)習(xí)筆記【基本概念、對(duì)象、過濾器、指令等】

    這篇文章主要介紹了Vue入門學(xué)習(xí)筆記,結(jié)合實(shí)例形式分析了vue.js的基本概念、對(duì)象、過濾器、指令等的相關(guān)原理與簡單使用方法,需要的朋友可以參考下
    2019-04-04
  • vue中使用moment設(shè)置倒計(jì)時(shí)的方法

    vue中使用moment設(shè)置倒計(jì)時(shí)的方法

    這篇文章給大家介紹了vue中使用moment設(shè)置倒計(jì)時(shí)的方法,文中通過代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • vue組件之間通信方式實(shí)例總結(jié)【8種方式】

    vue組件之間通信方式實(shí)例總結(jié)【8種方式】

    這篇文章主要介紹了vue組件之間通信方式,結(jié)合實(shí)例形式總結(jié)分析了vue.js的8種組件通信方式與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-02-02
  • vue中常見的問題及解決方法總結(jié)(推薦)

    vue中常見的問題及解決方法總結(jié)(推薦)

    這篇文章主要給大家介紹了關(guān)于vue中常見的問題及解決方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • vue3+TS reactive設(shè)定類型方式

    vue3+TS reactive設(shè)定類型方式

    這篇文章主要介紹了vue3+TS reactive設(shè)定類型方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Vue.js之VNode的使用

    Vue.js之VNode的使用

    這篇文章主要介紹了Vue.js之VNode的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • vue3中如何使用vue-types

    vue3中如何使用vue-types

    vue-types 在 Vue 3 中的使用主要適用于希望進(jìn)行更細(xì)致的 prop 驗(yàn)證的場景,尤其是在 JavaScript 項(xiàng)目中,這篇文章給大家介紹vue3中如何使用vue-types,感興趣的朋友跟隨小編一起看看吧
    2024-04-04

最新評(píng)論