// onlyNumber.js
var onlyNumber = {
inserted(el, vDir, vNode) {
// vDir.value 有指令的参数
let content;
//按键按下=>只允许输入 数字/小数点
el.addEventListener("keypress", event => {
let e = event || window.event;
let inputKey = String.fromCharCode(typeof e.charCode === ‘number‘ ? e.charCode : e.keyCode);
let re = /\d|\./;
content = e.target.value;
//定义方法,阻止输入
function preventInput() {
if(e.preventDefault) {
e.preventDefault();
} else {
e.returnValue = false;
}
}
if(!re.test(inputKey) && !e.ctrlKey) {
preventInput();
} else if(content.indexOf(".") > 0 && inputKey == ".") {
//已有小数点,再次输入小数点
preventInput();
}
});
//按键弹起=>并限制最大最小
// el.addEventListener("keyup", event => {
// let e = event || window.event;
// content = parseFloat(e.target.value);
// if(!content) {
// content = 0.00;
// }
// let arg_max = "";
// let arg_min = "";
// if(vDir.value) {
// arg_max = parseFloat(vDir.value.max);
// arg_min = parseFloat(vDir.value.min);
// }
// if(arg_max && content > arg_max) {
// e.target.value = arg_max;
// content = arg_max;
// }
// if(arg_min && content < arg_min) {
// e.target.value = arg_min;
// content = arg_min;
// }
// });
//失去焦点=>保留指定位小数
el.addEventListener("focusout", event => { //此处会在 el-input 的 @change 后执行
let e = event || window.event;
content = parseFloat(e.target.value);
if(!content) {
content = 0.00;
}
let arg_max = "";
let arg_min = "";
if(vDir.value) {
arg_max = parseFloat(vDir.value.max);
arg_min = parseFloat(vDir.value.min);
}
if(arg_max && content > arg_max) {
e.target.value = arg_max;
content = arg_max;
}
if(arg_min && content < arg_min) {
e.target.value = arg_min;
content = arg_min;
}
let arg_precision = 0; //默认保留至整数
if(vDir.value.precision) {
arg_precision = parseFloat(vDir.value.precision);
}
e.target.value = content.toFixed(arg_precision);
})
}
};
export default (Vue) => {
Vue.directive(‘onlyNumber‘, onlyNumber);
};
然后直接在main.js中引入后use一下就可以了
import onlyNumber from ‘@/js/onlyNumber‘;
Vue.use(onlyNumber);
使用:
<el-input v-only-number="{max:100,min:0.01,precision:2}" v-model=‘value‘ type=‘number‘></el-input>
原文:https://www.cnblogs.com/jaolo/p/11156342.html