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


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

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

    <input type="number"/>

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

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

    (1)使用onkeypress

    1. <input type="text" onkeypress="fun()"/>
    2. <script>
    3. function fun(){
    4. if( ){ // 判断条件
    5. return (event.returnValue = false) //就是这是输入会被限制住
    6. }
    7. }
    8. script>

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

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

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

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

    /条件/g

    (2) 使用onkeyup

    1. <input type="text" id="text_input" onkeyup="fun()"/>
    2. <script>
    3. funciton fun() {
    4. const filterCondition = ''//根据自己的需求写,正则可以表示成 /[!&#@]/
    5. const tile = document.querySelector('#text_input');
    6. tile.valuse = tile.valuse.replace('filterCondition','');
    7. }
    8. script>

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

    (3)onkeydown

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

    event.preventDefault();
    

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

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

  • 相关阅读:
    Leetcode 1492.n的第k个因子
    Splunk 之 filed 恢复
    Install kibana manually
    信泰如意享七金版养老年金保险怎么样,好不好?
    【Kotlin 协程】协程的挂起和恢复 ② ( 协程挂起 和 线程阻塞 对比 )
    GB/T28181协议介绍
    每日一记项目,拼图小游戏
    tidb-cdc同步到kafka报错cdc报错CDC:ErrKafkaNewSaramaProducer
    MindSpore术语歧义解释
    ant的FileSet资源集合
  • 原文地址:https://blog.csdn.net/weixin_42078672/article/details/127876254