element el-input 只能输入数字,限制最大最小,小数位数 --使用 directive

效果图:

条件:  限制最大 100,最小0,最长两位小数

输入大于100,自动变为100.

超出,2位小数,自动四舍五入

 

以下是使用全局指令的案例

(也可以使用局部指令,可以参考文档 https://cn.vuejs.org/v2/guide/custom-directive.html):

1.文件结构:

     文件夹结构, src 下新建一个 directive 文件夹

     directive 文件夹下又新建一个 el-input 文件夹

     el-input 文件夹下,新建 index.js 和 onlyNumber.js 文件

2.文件代码

onlyNumber.js   核心实现

export default {
    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_precision = 0;//默认保留至整数
            if (vDir.value.precision) {
                arg_precision = parseFloat(vDir.value.precision);
            }
            e.target.value = content.toFixed(arg_precision);
            // -- callback写法1
            // vNode.data.model.callback = ()=>{
            //     e.target.value = content.toFixed(arg_precision)
            // }
            // vNode.data.model.callback();
            // -- callback 写法2
            // vNode.data.model.callback(
            //     e.target.value = content.toFixed(arg_precision)
            // )
        })
    }
}

index.js  提供安装方法

import onlyNumber from './onlyNumber'
const install = Vue => {
  Vue.directive('onlyNumber', onlyNumber)
}
/*
  Vue.use( plugin )
  安装 Vue.js 插件。如果插件是一个对象,必须提供 install 方法。
  如果插件是一个函数,它会被作为 install 方法。install 方法调用时,会将 Vue 作为参数传入。
  该方法需要在调用 new Vue() 之前被调用。
  当 install 方法被同一个插件多次调用,插件将只会被安装一次。
*/

if (window.Vue) {
  window['onlyNumber'] = onlyNumber
  Vue.use(install); // eslint-disable-line
}

onlyNumber.install = install
export default onlyNumber

main.js   在入口 js 中添加两行,其他不要添加

import Vue from 'vue'
import App from './App'
import router from './router'
import api from './http'
import store from './store'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'

import onlyNumber from '@/directive/el-input'; //添加此行=>自定义全局指令


Vue.use(ElementUI)
Vue.use(api)

Vue.use(onlyNumber); //添加此行=>使用该全局指令

Vue.prototype.global = global

new Vue({
  el: '#app',
  router,
  store,
  render: h => h(App)
});

指令调用:

不用 import 导入直接使用, v-only-number="{max:100,min:0,precision:2}"

<el-input  v-model="inputVal" v-only-number="{max:100,min:0,precision:2}" size="mini" 
           placeholder="请输入受益比例">
     <template slot="append">%</template>
</el-input>

参考文档:

vue官方API:  https://cn.vuejs.org/v2/guide/custom-directive.html

MDN Web文档:  https://developer.mozilla.org/zh-CN/docs/Web/API/EventTarget/addEventListener

  • 7
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
要实现el-input只能输入数字限制数字的长度,可以使用以下代码: 在el-input标签中,添加oninput事件和maxlength属性。oninput事件可以使用正则表达式将非数字字符替换为空,从而只允许输入数字。maxlength属性可以限制输入的字符长度。 例如,可以参考引用中的代码: ``` <el-input placeholder="只能填写24位数字" v-model="scope.row.icode" type="text" maxlength="24" oninput="value=value.replace(/[^\d]/g,'')"></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中添加自定义指令。参考引用中的代码,其中使用了Vue.directive来定义一个名为enterNumber的指令,在inserted钩子函中添加keypress事件监听,通过正则表达式和条件判断来限制只能输入数字并阻止非数字字符的输入。 希望以上信息能帮到您。123 #### 引用[.reference_title] - *1* [vue el-input 只能输入数字限制长度](https://blog.csdn.net/m0_59605357/article/details/123504420)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *2* *3* [el-input 只能输入数字限制长度](https://blog.csdn.net/weixin_30781107/article/details/101617919)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值