javascript - 数字输入框
业务需求:限定输入框只能输入数字。
几个常见的做法:
-
使用 document.execCommand("Undo"),如果用户输入非数字,就撤销操作,可用,但是document是一个全局对象,对于前端的命令不是非常了解,不敢轻易尝试;
-
设置 input 为 number 类型,因为,字母 e 是属于科学记数法,所以,存在输入非数字的可能,可用,但是非要挑错,也有问题;
-
侦听松开键盘的事件,校验输入框内的数据。
(下列代码功能:如果输入框非数字,直接清除所有内容。可以进一步优化,返回上一步的状态)
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,自己据理力争就好了。
疯狂的妞妞 :每一天,做什么都好,不要什么都不做!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· 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