资讯专栏INFORMATION COLUMN

前端碎语(4)

zhiwei / 2472人阅读

摘要:键盘事件与文本框变化的过程键盘事件最基本的应用场合是控制文本框元素,而我们要讨论的,就是几个键盘事件发生的时机与文本输入的过程的关系。可以看到,除了外,事件并不会输出刚按下的字符,说明他们在文本框变化之前发生而在之后发生。

键盘事件与文本框变化的过程

键盘事件最基本的应用场合是控制文本框元素,而我们要讨论的,就是几个键盘事件:keydownkeypresskeyuptextInput发生的时机与文本输入的过程的关系。先看一段代码:

    
    

查看控制台可以看到键盘事件的执行顺序,这里事件的执行分为两种情况,一种是按下字符键,chrome下执行的顺序为keydown->keypress->textInput->keyup,如果按照不放就交替执行keydownkeypress;另一种是按下非字符键,chrome下执行顺序为keydown->keyup,如果按着不放就不停地执行keydown

事件的顺序搞清楚了,但我们还要看清键盘事件发生与文本框变化的顺序。把上面代码中的每个事件处理程序再加一句console.log(input.value),按一个字符。可以看到,除了keyup外,keydownkeypresstextInput事件并不会输出刚按下的字符,说明他们在文本框变化之前发生而keyup在之后发生。进一步地,也可以给每个事件加个alert()看看,虽然由于alert()的干扰导致keyup不发生(单步调试得出的结论),但这样一步步执行也能直观看出上面的结论。

理清这些关系有什么用呢?当然是为了起前端工程的一大目标:做出更好地交互。比如你要做个有关键词提示的搜索框,由于只有keyup事件是在文本框变化后触发的,也就意味着弹出提示的代码只有挂在keyup事件上才能在输入字符后获取到输入框最新的value,而挂在其他事件上就会出现提示与输入慢半拍的诡异现象。

最后要注意,虽然各浏览器基本遵循上面的事件执行顺序,但不同浏览器对键盘事件的实现仍有差别,比如火狐和IE并不支持textInput事件;而同时对于非字符键,也不一定就按上面提到的只响应keydownkeyup,比如在火狐下按backspace键也具有字符键的行为。

对用户输入字符进行正则转义

数据交互的可靠与安全是前端工程需要考虑的重要一环,我们的用户既可能输入一段有歧义的字符,也随时可能给你来段sql注入或xss,这里我也遇到一个简单点的情景:如何拿用户输入的内容来构建有效的正则进行查询。

考虑到用户可能会输入一些正则的专用符号,如果不对这些符号进行转义就直接把整个字符串拿去构造正则,那势必会使查询结果背离我们的本意。正则表达式里对特殊符号转义只要在前面加,所以思路就是将源字符串中的特殊符号替换为待转义字符。实现如下:

    function transfer(string) {
        return string.replace(/[./^$*+?[]()]/g, "$&");
    }

用到了字符串的replace方法,第一个参数一个是全局匹配所有待转义字符的正则;第二个参数是个$表达式,$&获取所有与正则相匹配的子串,注意这里要在其前面加上而非,因为在普通字符串里使用也得写为进行转义。

可能有人会问,$&不是相当于RegExp.lastmatch匹配最近一次匹配项吗,为何使用它获取全局正则的所有匹配项?

可以这么想,replace对全局正则匹配项的替换是逐个进行的,每匹配一个子串就用第二个参数的规则替换一次。所以用$&每次替换最近一次匹配项,也就能到达看起来一次替换了全局正则的所有匹配项效果。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/87711.html

相关文章

  • 前端碎语(6)

    摘要:和属性数值对应的是元素的内容加所占据的视觉面积,有滚动条时还要加上滚动条,不含。和仍要分有没有滚动,有滚动时指的是整个页面内容的大小没滚动时在下指视口的大小和下则是和一样。与属性在下都和原来一样指整个元素的可视宽高。 光标效果不见了? 在页面里,屏幕上光标的样式我们可以用css的cursor属性进行定义。一般来讲,只要光标hover到指定的元素上面其样式就会按我们指定的进行显示,但是如...

    Youngs 评论0 收藏0
  • 前端碎语(6)

    摘要:和属性数值对应的是元素的内容加所占据的视觉面积,有滚动条时还要加上滚动条,不含。和仍要分有没有滚动,有滚动时指的是整个页面内容的大小没滚动时在下指视口的大小和下则是和一样。与属性在下都和原来一样指整个元素的可视宽高。 光标效果不见了? 在页面里,屏幕上光标的样式我们可以用css的cursor属性进行定义。一般来讲,只要光标hover到指定的元素上面其样式就会按我们指定的进行显示,但是如...

    edagarli 评论0 收藏0
  • 前端碎语(5)

    摘要:禁止用户选择文字在一些应用场合,我们不希望用户能够选择文字。在下使用透明效果虽然已经停止对的技术支持了,然而做前端的还得被它恶心一段时间,有些兼容性的问题是我们仍要面对滴。但是,前端界被虐了这么多年,解决问题的方法总是有的。 禁止用户选择文字 在一些应用场合,我们不希望用户能够选择文字。比如在拖动交互中,如果用户能选择元素内部的文字,也就意味着能拖动它们,这样就会干扰对元素的拖动、影响...

    xiaoqibTn 评论0 收藏0
  • 前端碎语(5)

    摘要:禁止用户选择文字在一些应用场合,我们不希望用户能够选择文字。在下使用透明效果虽然已经停止对的技术支持了,然而做前端的还得被它恶心一段时间,有些兼容性的问题是我们仍要面对滴。但是,前端界被虐了这么多年,解决问题的方法总是有的。 禁止用户选择文字 在一些应用场合,我们不希望用户能够选择文字。比如在拖动交互中,如果用户能选择元素内部的文字,也就意味着能拖动它们,这样就会干扰对元素的拖动、影响...

    xialong 评论0 收藏0
  • 前端碎语(2)

    摘要:和并不是一个标准的属性,才是,所以火狐长久以来都不支持,同时也不支持。 这个系列保持开坑不埋的状态已经过去三个月了,而在这几个月中我才算第一次认真地深入理解js。虽然期间笔记是记了不少,但写博文又不应是简单的复制粘贴,还是得保证有讨论价值、有干货的。而我面对的现实是:一来基础差导致识别和捞出有讨论价值的干货得自身功夫练到一定阶段,二来又因为记的杂乱且缺乏日常整理,整理一下就是拖一下,再...

    FrancisSoung 评论0 收藏0

发表评论

0条评论

zhiwei

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<