javascript - 数字输入框

业务需求:限定输入框只能输入数字。

几个常见的做法:

  1. 使用 document.execCommand("Undo"),如果用户输入非数字,就撤销操作,可用,但是document是一个全局对象,对于前端的命令不是非常了解,不敢轻易尝试;

  2. 设置 input 为 number 类型,因为,字母 e 是属于科学记数法,所以,存在输入非数字的可能,可用,但是非要挑错,也有问题;

  3. 侦听松开键盘的事件,校验输入框内的数据。

(下列代码功能:如果输入框非数字,直接清除所有内容。可以进一步优化,返回上一步的状态)

 thisObj.find("#userName").bind("onafterpaste keyup",function (evt) {
   var my = $(this), v = my.val();
   if(isNaN(v)){
     my.val(v.replace(/[^\d]/g,''));
   }
 });

推荐做法

一般我们选择方式 2 即可,设置 input 为 number 类型。

能做,但是没必要,因为系统不会只校验一次,有其它校验方式,保证最终的结果正确。

会纠结这个问题,估计是测试人员找茬,说你的输入框能输入字母e,自己据理力争就好了。

posted on   疯狂的妞妞  阅读(967)  评论(0编辑  收藏  举报

(评论功能已被禁用)
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示