onkeyup事件导致输入框内容显示有误 (对于Windows输入法)

项目场景:

对输入框限制输入内容 有些特殊符号转化为空格 


问题描述

今天同事发现他用最原始的windows输入法去输入内容时 框内把内容的拼音也带上了 ,原来使用的方法是这个:

onkeyup="value=value.replace(/([^0-9A-z\u4e00-\u9fa5]|[\^\_\]\[`])/g,' ').replace(/( )+/g,'')"

原因分析:

这个方法在输入中文内容时,表单校验会不通过。 输入的内容变成新的变量了,但是表单校验监听不到这个新变量,输入框内展示的内容就会是错误的


解决方案:

后来面向百度,找到了解决办法: 使用input事件 将新填入的变量进行正则校验后 再赋值给input输入框绑定的变量,这样就能监听到这个替换后的变量

//标签上绑定的input事件
@input="showInpKey(form[field.FIELDNAME + '-' + field.TYPE], field)"


//方法
showInpKey(value, field) {
    const reg = /([^0-9A-z\u4e00-\u9fa5]|[\^\_\]\[`])/g; // 匹配非数字、字母、汉字
    if(reg.test(value)){
        value = value.replace(reg, ' ');
     }

     this.form[field.FIELDNAME + '-' + field.TYPE] = value.replace(/( )+/g, ' '); //输入多个空格也只展示一个空格
 },

今年的班就先上到这里咯 ,明年在上! 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值