• 【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是键盘上所有的按键被按下时都会触发,而且字母不区分大小写

  • 相关阅读:
    Prometheus邮件告警
    300行代码实现Minecraft(我的世界)大地图生成
    【Java面试】Cookie和Session的区别
    亚马逊国际获得AMAZON商品详情 API 返回值说明
    【MySQL篇】多表查询知识点——子查询(全)
    【左程云算法全讲2】链表、栈、队列、递归、哈希表和有序表
    住宅代理详细介绍——助您快速入门!
    刷题记录:牛客NC19916[CQOI2010]扑克牌
    2022-6-2
    常见数据库介绍对比之SQL关系型数据库
  • 原文地址:https://blog.csdn.net/weixin_42078672/article/details/127876254