国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue from-validate 表單驗證的示例代碼

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

前言

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

知識準備

vue的自定義指令

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

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

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

開始

1、指令的申明

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

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

2、解析參數

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

3、輸入內容改變時進行規(guī)則驗證

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

4、在提交時對所有數據進行校驗

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

5、校驗規(guī)則實例

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

結束

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 泗水县| 肥乡县| 富源县| 华蓥市| 德江县| 伊金霍洛旗| 淳化县| 柏乡县| 澳门| 芜湖县| 额尔古纳市| 盘山县| 平和县| 南陵县| 巴马| 江油市| 肥西县| 盐山县| 博兴县| 根河市| 囊谦县| 胶南市| 麦盖提县| 石渠县| 正蓝旗| 慈利县| 刚察县| 丰原市| 肃宁县| 会宁县| 莱阳市| 吉安市| 鲁山县| 麻城市| 河北区| 海原县| 景德镇市| 会理县| 邵阳县| 临沭县| 吉首市|