el-input 只能输入数字并限制长度

在上一个博客中,有关于限制长度的使用,本文介绍限制只能输入数字的方法

el-input 代码如下:

<el-form-item label="账号" required>
    <el-input v-model="form.tele" style="width:160px;" oninput="if(value.length>11)value=value.slice(0,11)" placeholder="请输入账号" type="number"></el-input>
    </el-form-item>

 

在main.js中加入如下代码:

 1 Vue.directive('enterNumber', {
 2   inserted: function (el) {
 3     el.addEventListener("keypress",function(e){
 4       e = e || window.event;
 5       let charcode = typeof e.charCode === 'number' ? e.charCode : e.keyCode;
 6       let re = /\d/;
 7       if(!re.test(String.fromCharCode(charcode)) && charcode > 9 && !e.ctrlKey){
 8         if(e.preventDefault){
 9           e.preventDefault();
10         }else{
11           e.returnValue = false;
12         }
13       }
14     });
15   }
16 });

 

演示如下:

 

posted @ 2019-09-03 16:09  菜小鱼~  阅读(22369)  评论(0编辑  收藏  举报