vue input標簽通用指令校驗的實現(xiàn)
移動端通常對于input標簽要求輸入有一些校驗,vue的指令可達到完美校驗的作用
預期效果
<input v-model="times" :data-last_value="lastTimes" v-int v-max="8" v-min="2" />
屬性data-last_value的值用來緩存用戶輸入框上一次失去焦點后輸入的值,lastTimes是初始化的變量,后續(xù)不會再隨意更改此值, v-model一定不要和data-last_value綁定同一個變量, 因為這樣就起不到記住用戶上一次輸入值,并利用該值在校驗不通過的情況下使用它
指令實現(xiàn)
以下3個指令可完全獨立使用
校驗整數(shù)
const util = {
isNumber(str) {
const num = Number(str);
return Math.floor(num) === num;
}
};
directives: {
int: {
inserted: (el) => {
let oldListener = el.onblur;
el.onblur = (e) => {
if (oldListener) {
oldListener(e);
}
const blurValue = Number(el.value);
// 用data-last_value屬性值緩存上一次的值,以便恢復
const lastValue = el.getAttribute('data-last_value');
if (!util.isNumber(blurValue)) {
util.toast('請輸入數(shù)字');
el.value = lastValue;
el.dispatchEvent(new Event('input'));
}
if (el.value === lastValue) return;
// 更新上一次的值
el.setAttribute('data-last_value', el.value);
}
},
},
}
校驗最小值
directives: {
min: {
inserted: (el, binding) => {
const oldListener = el.onblur;
el.onblur = (e) => {
if (oldListener) {
oldListener(e);
}
const blurValue = Number(el.value);
const min = binding.value;
if (blurValue < min) {
// util.toast替換成自己業(yè)務(wù)的toast提示彈窗
util.toast(`最小值不能小于${min}`);
el.value = min;
el.dispatchEvent(new Event('input'));
}
const lastValue = el.getAttribute('data-last_value');
if (el.value === lastValue) return;
// 更新上一次的值
el.setAttribute('data-last_value', el.value);
}
},
},
}
校驗最大值
directives: {
max: {
// 指令的定義
inserted: (el, binding) => {
const oldListener = el.onblur;
el.onblur = (e) => {
if (oldListener) {
oldListener(e);
}
const blurValue = Number(el.value);
const max = binding.value;
if (blurValue > max) {
util.toast(`最大值不能大于${max}`);
el.value = max;
el.dispatchEvent(new Event('input'));
}
const lastValue = el.getAttribute('data-last_value');
if (el.value === lastValue) return;
// 更新上一次的值
el.setAttribute('data-last_value', el.value);
}
},
},
}
小小的校驗指令沒想到里面還有那么多細節(jié)~~~
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
VUEJS實戰(zhàn)之利用laypage插件實現(xiàn)分頁(3)
這篇文章主要為大家詳細介紹了VUEJS實戰(zhàn)之修復錯誤并且美化時間,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-06-06
vue-tree-chart樹形組件的實現(xiàn)(含鼠標右擊事件)
Vue-Tree-Chart,一個Vue.js2組件,本文就詳細的介紹一下vue-tree-chart樹形組件的實現(xiàn)(含鼠標右擊事件),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02
element-ui動態(tài)級聯(lián)選擇器回顯問題詳解(二十多行代碼搞定)
大家在使用element-ui的時候肯定會遇到這樣一個問題,就是在你使用級聯(lián)選擇器的回顯問題,下面這篇文章主要給大家介紹了關(guān)于element-ui動態(tài)級聯(lián)選擇器回顯問題的相關(guān)資料,需要的朋友可以參考下2023-03-03
Vue中動態(tài)權(quán)限到按鈕的完整實現(xiàn)方案詳解
這篇文章主要為大家詳細介紹了Vue如何在現(xiàn)有方案的基礎(chǔ)上加入對路由的增、刪、改、查權(quán)限控制,感興趣的小伙伴可以跟隨小編一起學習一下2025-03-03
vxe-table?實現(xiàn)表格數(shù)據(jù)分組功能(按指定字段數(shù)據(jù)分組)
文章介紹了如何使用樹結(jié)構(gòu)實現(xiàn)表格數(shù)據(jù)分組,并提供了官方文檔的鏈接,本文結(jié)合實例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2024-11-11
Vue按照順序?qū)崿F(xiàn)多級彈窗效果 附Demo
這篇文章主要介紹了Vue按照順序?qū)崿F(xiàn)多級彈窗效果 附Demo,通過實例代碼介紹了單個彈窗和多級彈窗的實現(xiàn)方法,感興趣的朋友跟隨小編一起看看吧2024-05-05
vue v-on:click傳遞動態(tài)參數(shù)的步驟
這篇文章主要介紹了vue v-on:click傳遞動態(tài)參數(shù)的步驟,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09

