el-element 中 input设置了type=“number“还能输入e和负数的问题如何解决?

1. el-input设置了type=“number“还能输入e和负数

<el-input v-model="name" onkeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)));"/>

2.el-input设置了type=“number“, 只能输入数字和英文逗号

                    <el-input
                        v-model.number="query.ruleId"
                        oninput="query.ruleId.replace(/[^\d,]/g,'')"
                        type="number"
                        placeholder="请输入纯数字的策略ID"
                    />

3.el-input 设置了type=“number“,但是有上下箭头的样式

 // 去除上下箭头
 ::v-deep input::-webkit-outer-spin-button,
 ::v-deep input::-webkit-inner-spin-button {
 -webkit-appearance: none !important;
 }
 ::v-deep input[type='number'] {
 -moz-appearance: textfield !important;
 }

 // 去除光标偏移
 
::v-deep .el-input__inner{
        line-height: 1px !important;
}

4.禁止键盘上下键事件

    mounted() {
        this.showkey();
    },
    methods: {
        // el-input type=number时,如果点击键盘上下可以改变input中的值,这个方法是禁止改变
        showkey() {
            document.onkeydown = function () {
                if (window.event.keyCode === 38 || window.event.keyCode === 40) {
                    window.event.returnValue = false;
                }
            };
        },

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值