js input手机号正则限制11位数字

**  h5开发 js代码限制 input 输入框只能输入纯数字**
(1)方案一

javascript 复制代码
onkeyup = "value=value.replace(/[^\d]/g,'')"

使用 onkeyup 事件有 Bug ,就是在中文输入法状态下,输入汉字之后回车,会直接输入字母

(2)方案二

javascript 复制代码
onchange = "value=value.replace(/[^\d]/g,'')"

使用 onchange 事件,在输入内容后,只有 input 丧失焦点时才会得到结果,并不能在输入时就做出响应

(3)方案三

javascript 复制代码
oninput = "value=value.replace(/[^\d]/g,'')"

使用 oninput 事件,完美的解决了以上两种问题,测试暂时还没有出现其它问题

测试

javascript 复制代码
<input type="text" maxlength="11" oninput = "value=value.replace(/[^\d]/g,'')"  placeholder="请输入您的手机号">

接着加个maxlength="11" 限制只能输入位数为11位;

js验证代码

javascript 复制代码
var num = document.getElementById('num');
                if(num.value.length != 18){
                    alert('输入正确的身份证号码');
                    num.focus();
                    return false;
                }
javascript 复制代码
var phone_reg = /^13[0-9]{1}[0-9]{8}$|15[0-9]{1}[0-9]{8}$|18[0-9]{1}[0-9]{8}|17[0-9]{1}[0-9]{8}$|14[0-9]{1}[0-9]{8}/;
                    var tel_reg = /^([0-9]{3,4}-)?[0-9]{7,8}$/;
                    if(!phone_reg.test(phone.value) && !tel_reg.test(phone.value)){
                        alert('手机或电话号码格式不正确。如果是固定电话,必须形如(xxxx-xxxxxxxx)');
                        phone.focus();
                        return false;
                    }
相关推荐
XS0301063 分钟前
Servlet+JQuery实现数据库数据渲染到前端页面
前端·servlet·jquery
code bean5 分钟前
【LangChain】少样本提示(Few-Shot Prompting)实战指南
开发语言·python·langchain
AI人工智能+电脑小能手8 分钟前
【大白话说Java面试题 第42题】【JVM篇】第2题:JVM内存模型有哪些组成部分?
java·开发语言·jvm·面试
yqcoder8 分钟前
深入理解 JavaScript:什么是可迭代对象 (Iterable)?
开发语言·javascript·网络
破阵子4432812 分钟前
如何用 Claude Code 等 Agent 工具操作 MATLAB(支持代码编写及 Simulink)
开发语言·matlab
AI人工智能+电脑小能手15 分钟前
【大白话说Java面试题 第43题】【JVM篇】第3题:GC分为哪两种?Young GC 和 Full GC有什么区别?
java·开发语言·jvm·后端·面试
van久20 分钟前
Day27:菜单管理 + 动态路由(前端可直接用!)
前端·状态模式
恋猫de小郭24 分钟前
DeepSeek V4 Flash 可以在 128GB 的 M3 Max 运行,还是 1M 上下文
前端·人工智能·ai编程
van久25 分钟前
企业级后台管理系统(结合前 4 周全部内容)详细需求文档 + 前端模板适配
前端
Bear on Toilet25 分钟前
【JSON-RPC远程过程调用组件库】测试报告
开发语言·软件测试·后端·自动化脚本