【HTML】<input>限制字符输入

有时候我们希望限制一个特殊字符输入

1. 如果仅仅是可以输入数字,那么我们可以直接在type那些限制

<input type="number"/>

这样在这个输入框中就只能输入数字,其他都会别限制住。

2. 如果限制的是一些特殊符号,最主要是为了防止注入攻击,可以采取以下的方法:

(1)使用onkeypress

<input type="text" onkeypress="fun()"/>

<script>
    function fun(){
        if( ){   // 判断条件
            return (event.returnValue = false)  //就是这是输入会被限制住
        }
    }

</script>

对于如何处理判断条件的问题

- 直接读取对于的 keycode,写法就是 event.keyCode

- 将keyCode转换为对于的值,可以使用 String.fromCharCode(),将对于的键值转换文对应的文本,

同时这个方法可以解决复制粘贴的问题,因为将文本复制到这个边框的时候,下面的方法是无法排除的,这个方法可以,使用正则时候需要在表达式的最后使用全局变量,否则只能过滤一部分

/条件/g

(2) 使用onkeyup

<input type="text" id="text_input" onkeyup="fun()"/>

<script>
    funciton fun() {
        const filterCondition = ''//根据自己的需求写,正则可以表示成 /[!&#@]/
        const tile = document.querySelector('#text_input');
        tile.valuse = tile.valuse.replace('filterCondition','');
    }
</script>

这种方式就是会有闪动,就是等你输入以后再删除,比较适合粘贴以后,有特殊字符帮你过滤,直接输入,就需要添加提示吧,不然用户输入一个值以后都不知道你为什么闪掉,会很影响用户体验的。

(3)onkeydown

这个方法和onkeypress有点类似,但是他实现上最主要是通过监听,他的控制主要通过

event.preventDefault();

不过不同的是 onkeypress是字母或数字键盘被按下时才触发(ctrl shift这些不会触发)

而onkeydown是键盘上所有的按键被按下时都会触发,而且字母不区分大小写

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值