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

Vue from-validate 表單驗(yàn)證的示例代碼

 更新時(shí)間:2017年09月26日 11:43:49   作者:_塵_  
本篇文章主要介紹了Vue from-validate 表單驗(yàn)證的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

前言

需要進(jìn)行表單數(shù)據(jù)驗(yàn)證,原先才用html5來完成驗(yàn)證,但是效果很差,也不夠靈活,所以需要進(jìn)行自定義的表單驗(yàn)證,網(wǎng)上的插件都太過龐大,項(xiàng)目并沒有這么多的需求。
那讓我們自己來寫一個(gè)吧!

知識準(zhǔn)備

vue的自定義指令

具體可以看官方手冊,連接如下:https://vuejs.org/v2/guide/custom-directive.html

總的來說就是可以幫你在指定的鉤子函數(shù)中跳用你的函數(shù),參數(shù)(el,binding, vnode)

  • el: 綁定的dom
  • binding: 指令的各項(xiàng)屬性
  • vnode: Vue 編譯生成的虛擬節(jié)點(diǎn)

開始

1、指令的申明

需要注意的是參數(shù)在背綁定上后不會(huì)被所以要才用閉包的方式

Vue.directive('validate', {
 // 在指令第一次背綁定上時(shí)調(diào)用
 bind(el, binding, vnode) {
 }
}
<form id="red-package" @submit.prevent="submit" v-validate.formData="validate">
 ...
 <button type="submit" class="save">保存</button>
</form>

2、解析參數(shù)

Vue.directive('validate', {
 // vm對象,就是組件
 const vm = vnode.context;
 // 獲得參數(shù)綁定的參數(shù),就是規(guī)則對象
 const validate = binding.value;
 // 獲得數(shù)據(jù)的key
 const dataKey = Object.keys(binding.modifiers)[0];
});

3、輸入內(nèi)容改變時(shí)進(jìn)行規(guī)則驗(yàn)證

el.addEventListener('change', (e) => {
 try {
  // 事件觸發(fā)的input標(biāo)簽名
  const changeElName = e.srcElement.name;
  // 如果未設(shè)定規(guī)則不驗(yàn)證
  if (validate[changeElName]) {
   // 把表單的所有參數(shù)傳入
   validate[changeElName](vm[dataKey]);
   // 檢驗(yàn)成功添加成功的class
   Util.removeClass(e.srcElement, 'success');
  }
 } catch (err) {
  // 拋出異常添加失敗的class
  Util.addClass(e.srcElement, 'error');
 }
});

4、在提交時(shí)對所有數(shù)據(jù)進(jìn)行校驗(yàn)

// 有更好的方案
el.getElementsByTagName('button')[0].addEventListener('click', (e) => {
 try {
  // 遍歷對象
  Object.keys(vm[dataKey]).forEach((item) => {
   if (validate[item]) {
    validate[item](vm[dataKey]);
   }
  });
 } catch (err) {
  // 拋出錯(cuò)誤提示
  vm.loading({
   text: '請檢查參數(shù)',
  });
  vm.loaded(1000);
  // 阻止submit
  e.preventDefault();
 }
});

5、校驗(yàn)規(guī)則實(shí)例

amountRandomUpper({ budget, amountRandomUpper, amountRandomLower }) {
  if (amountRandomUpper < 1) {
    throw new Error('過小');
  }
  if (amountRandomUpper < amountRandomLower) {
    throw new Error('過小');
  }
  if (amountRandomUpper > budget) {
    throw new Error('過小');
  }
}

結(jié)束

這當(dāng)中還是存在很多問題,有什么好的建議希望可以指出

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

相關(guān)文章

  • Vue3指令之搜索框輸入防抖功能實(shí)現(xiàn)

    Vue3指令之搜索框輸入防抖功能實(shí)現(xiàn)

    在Vue開發(fā)中遇到了搜索框輸入防抖處理,算是防抖的使用場景之一吧,這篇文章主要給大家介紹了關(guān)于Vue3指令之搜索框輸入防抖功能實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • 解決vant-UI庫修改樣式無效的問題

    解決vant-UI庫修改樣式無效的問題

    這篇文章主要介紹了解決vant-UI庫修改樣式無效的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue項(xiàng)目中如何使用mock你知道嗎

    vue項(xiàng)目中如何使用mock你知道嗎

    這篇文章主要為大家介紹了vue項(xiàng)目如何使用mock,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • el-date-picker設(shè)置日期默認(rèn)值兩種方法(當(dāng)月月初至月末)

    el-date-picker設(shè)置日期默認(rèn)值兩種方法(當(dāng)月月初至月末)

    這篇文章主要給大家介紹了關(guān)于el-date-picker設(shè)置日期默認(rèn)值(當(dāng)月月初至月末)的相關(guān)資料,文中通過代碼示例將解決的辦法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • 學(xué)習(xí)vue.js計(jì)算屬性

    學(xué)習(xí)vue.js計(jì)算屬性

    這篇文章主要和大家一起學(xué)習(xí)vue.js的計(jì)算屬性,分享一些計(jì)算屬性練習(xí)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 一文了解axios和vue的整合操作

    一文了解axios和vue的整合操作

    axios作為Vue生態(tài)系統(tǒng)中濃墨重彩的一筆,我學(xué)習(xí)這個(gè)東西也是花了一定的時(shí)間的,下面這篇文章主要給大家介紹了關(guān)于axios和vue整合操作的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • vue-router+vuex addRoutes實(shí)現(xiàn)路由動(dòng)態(tài)加載及菜單動(dòng)態(tài)加載

    vue-router+vuex addRoutes實(shí)現(xiàn)路由動(dòng)態(tài)加載及菜單動(dòng)態(tài)加載

    本篇文章主要介紹了vue-router+vuex addRoutes實(shí)現(xiàn)路由動(dòng)態(tài)加載及菜單動(dòng)態(tài)加載,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • Vue.js實(shí)現(xiàn)拖放效果的實(shí)例

    Vue.js實(shí)現(xiàn)拖放效果的實(shí)例

    這篇文章主要介紹了Vue.js實(shí)現(xiàn)拖放效果的實(shí)例的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-09-09
  • vue中組件樣式?jīng)_突的問題解決

    vue中組件樣式?jīng)_突的問題解決

    默認(rèn)情況下,寫在.vue組件中的樣式會(huì)全局生效,因此很容易造成組件之間的樣式?jīng)_突問題,本文就來介紹一下如何解決此問題,感興趣的可以了解一下
    2023-12-12
  • vue arco.design錨點(diǎn)Anchor使用方式

    vue arco.design錨點(diǎn)Anchor使用方式

    這篇文章主要介紹了vue arco.design錨點(diǎn)Anchor使用方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04

最新評論