Vue from-validate 表單驗(yàn)證的示例代碼
前言
需要進(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)文章
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-08vue-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-09Vue.js實(shí)現(xiàn)拖放效果的實(shí)例
這篇文章主要介紹了Vue.js實(shí)現(xiàn)拖放效果的實(shí)例的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09vue arco.design錨點(diǎn)Anchor使用方式
這篇文章主要介紹了vue arco.design錨點(diǎn)Anchor使用方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04