html输入转换半角,Web前端开发:聊聊input输入框全角和半角应用

143e001e5344f0e7219c15080cde546b.png

最近在开发一个国际业务的开户注册项目的时候,遇到关于input输入的问题,涉及到全角和半角的问题,刚开始的时候只是按照国内正常的去判断的。

问题

其他国家的user,输入有时候会用全角,会报错,因为接口都是半角返回的数据。是会联想到输入法的问题咯,毕竟我们不能强制让用户去换输入法吧,这是不合情理的。

所以只有我们自己去解决。

解决方案

最开始的方案是,加一句提示,让用户不要用全角输入,用半角。

562d3010afade0f7155059240cf38b57.png

很明显这种方案看上去可以,但是产品那边是通不过的。

所以想到另外一个方案,就是用户输入全角的时候,直接自动转换成半角。这样看上去就很智能了。比如全角输入2334,直接就转了。

3998fb136eab1a622e2afb78b5ebd971.png

那么如何去实现呢?

因为快下班了,这里我就直接贴上写好的DEMO代码,用一个函数去控制:function checkBanj(obj){

var str=obj.value;

var result="";

for (var i = 0; i 

if (str.charCodeAt(i)==12288){

result+= String.fromCharCode(str.charCodeAt(i)-12256);

continue;

}

if (str.charCodeAt(i)>65280 && str.charCodeAt(i)<65375)

result+= String.fromCharCode(str.charCodeAt(i)-65248);

else result+= String.fromCharCode(str.charCodeAt(i));

}

obj.value=result;

}

在全角的时候,我们进行判断,然后通过字段去转换下就可以了。然后试着去运行了 ,居然是完美符合产品的要求啦。

完整DEMO:html>

Web前端开发:聊聊input输入框全角和半角应用 - Web前端之家https://www.jiangweishan.com

function checkBanj(obj){

var str=obj.value;

var result="";

for (var i = 0; i 

if (str.charCodeAt(i)==12288){

result+= String.fromCharCode(str.charCodeAt(i)-12256);

continue;

}

if (str.charCodeAt(i)>65280 && str.charCodeAt(i)<65375)

result+= String.fromCharCode(str.charCodeAt(i)-65248);

else result+= String.fromCharCode(str.charCodeAt(i));

}

obj.value=result;

}

试试吧!!!!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值