中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vuelidate對于vueJs2.0驗證的示例分析

發布時間:2021-08-02 14:51:58 來源:億速云 閱讀:159 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關vuelidate對于vueJs2.0驗證的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

介紹

在后端項目里 比如我們的Laravel框架 對于表單驗證有自己的一套validation機制 他將驗證集成在FormRequest

我們只需要在我們的方法中依賴注入我們自己實例化后的驗證類 當然也可以直接去在方法里去驗證表單數據

而在我們的前端的項目里 也就是在我們的vue項目里 也有比較好的驗證解決方案 也就是這的vuelidate

1.安裝

和我們安裝前端包一樣 在項目終端執行:

$ npm install vuelidate --save

安裝完成后和我們去使用vuex一樣 在main.js去引入聲明這個package:

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

當然你也可以在需要用到驗證的組件里去引用一個相對小的版本:

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.使用

其實使用起來真的很方便 下面舉例來說就是在我的項目里的使用

1.注冊驗證

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

首先我在Register.vue這個組件文件中把基本的樣式結構寫好 這取決于每個人

接著是我們對表單數據的驗證:

這里是對用戶名和郵箱的驗證 就像之前提到的 我們先引入我們的驗證規則:

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

因為我是對一個新用戶的注冊 所以我定義一個data

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

接著去定義我們的驗證字段的規則:

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

定義這些驗證規則之后 下面是我的html部分內容

<div class="control-group" v-bind:class="{ 'form-group--error': $v.newUser.name.$error }">
<label class="control-label">用戶名</label>
<el-input
    placeholder="請輸入你的用戶名"
    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="請輸入你的郵箱"
    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">請填寫正確的郵箱格式</span>

每個人可以都不一樣 官方文檔上也給出了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里面的內容

也就是 $invalid $dirty $error $pending $each 這個value

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

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

當然還有兩個重要的方法: $touch $reset 上面也有實例 說簡單點就是設置這個以及子節點的$dirty 為true或者false

而設置這個$dirty 再結合 $invalid就可以判斷驗證成功與否

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

在這里的驗證規則流程是這樣的 如果$error為true那么form-group會添加一個form-group--error這個class

只有在$error為true時 如果你不符合任意一個驗證規則 例如不符合required 那么就會提示驗證失敗

如果驗證錯誤就給出錯誤提示 這是我的錯誤樣式:

.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.密碼驗證

密碼驗證其實和上面的差不多 只不過他的驗證規則時通過 sameAs 來進行驗證的

3.組合驗證

除了上面這些還有一個組合驗證 也就是如果任意一個不符合驗證規則就不通過 這個還是挺常用的

我們可以在驗證字段這樣去組合:

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

如果任意一個就是FlatA flatB forGroup其中一個不符合驗證規則 那么$v.validationGroup.$error就是false

4.異步驗證

特別是在驗證唯一性的時候 我們肯定會遇到這樣的一個場景:

就比如我們的郵箱 如果已經注冊過這個郵箱了 那么再用這個郵箱去注冊顯然不是我們想要的

還有就是我們登錄時我們需要去核對我們的用戶的密碼

這邊我給出的實例就是對于用戶名的注冊 如果已經注冊了就會提示已經注冊過

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

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

這里我現在本地測試 通過Laravel作為后端來提供的數據校驗 實際項目中的話可以再結合數據庫

//用戶驗證路由
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);
  });
});

如果我們去注冊 gavin這個用戶就會提示該昵稱已經被注冊 因為在用戶名我增加了isUnique驗證

復制代碼 代碼如下:


<span class="form-group__message" v-if="!$v.newUser.name.isUnique">用戶名已經被注冊</span>

顯示結果應該是這樣的:

vuelidate對于vueJs2.0驗證的示例分析

5.自定義驗證

同樣的我們不僅可以使用它提供給我們的驗證規則 我們也可以自定義驗證規則并與之前的進行組合

官方給出了一個簡單實例:

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

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

關于“vuelidate對于vueJs2.0驗證的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

罗城| 巴彦县| 西乌珠穆沁旗| 巴中市| 徐汇区| 射阳县| 嫩江县| 栾城县| 河西区| 大方县| 邵东县| 灌阳县| 孙吴县| 凤山市| 岳阳县| 台南市| 孝昌县| 启东市| 凤凰县| 河间市| 谷城县| 闻喜县| 远安县| 莎车县| 油尖旺区| 雅安市| 峨眉山市| 瑞安市| 五常市| 大方县| 烟台市| 德庆县| 开江县| 汕尾市| 大冶市| 广昌县| 淳安县| 乃东县| 大英县| 康平县| 新化县|