前言
需要進行表單數據驗證,原先才用html5來完成驗證,但是效果很差,也不夠靈活,所以需要進行自定義的表單驗證,網上的插件都太過龐大,項目并沒有這么多的需求。
那讓我們自己來寫一個吧!
知識準備
vue的自定義指令
具體可以看官方手冊,連接如下:https://vuejs.org/v2/guide/custom-directive.html
總的來說就是可以幫你在指定的鉤子函數中跳用你的函數,參數(el,binding, vnode)
開始
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('過小'); }}結束
這當中還是存在很多問題,有什么好的建議希望可以指出
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答