如何实现javascript表单验证_正则表达式有哪些实用技巧
#技术教程 发布时间: 2025-12-31
JavaScript表单验证应“提前拦截+清晰反馈”,邮箱验证需避免简单正则,推荐/^1+@2+.3+$/并限制长度。\s@ ↩\s@ ↩\s@ ↩
JavaScript 表单验证结合正则表达式,核心在于“提前拦截 + 清晰反馈”,而不是等用户提交后才报错。正则不是越复杂越好,关键是匹配常见、典型、有边界的真实输入场景。
邮箱验证:
别只信 /\S+@\S+\.\S+/
这个简单写法会通过 test@.com 或 a@b.c,明显不合规范。更实用的是:
- 用
/^[^\s@]+@[^\s@]+\.[^\s@]+$/拦住空格和连续 @; - 加长度限制:
value.length (RFC 5321 规定邮箱总长上限); - 前端验证不替代后端校验,仅提升体验——真正发邮件前仍需 SMTP 确认。
手机号验证:按地区区分,避免一刀切
国内手机号常用 /^1[3-9]\d{9}$/,但它会放过已停用号段(如 140–144),也未考虑携号转网后的虚拟运营商号(如 170/171)。更稳妥的做法:
- 优先用运营商最新号段表做白名单匹配(可存为数组或正则分支);
- 对输入实时去空格、去短横线:
value.replace(/[\s\-()]/g, ''); - 中文界面建议提示“请输入 11 位中国大陆手机号”,比模糊提示更有效。
密码强度:用多个小正则,比一个大正则更可控
写一个 /(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[!@#]).{8,}/ 看似全面,但用户根本不知道缺哪项。推荐分步检查:
-
/.{8,}/→ 长度 ≥ 8; → 含小写字母;
→ 含大写字母;→ 含数字;
]/ → 含特殊字符(按产品策略选)。
每项单独判断,对应显示✔️或文字提示(如“请添加一个大写字母”),体验更好。
身份证号:校验位算法比正则更重要
18 位身份证不能只靠 /^\d{17}[\dXx]$/。必须验证最后一位校验码:
- 前 17 位转数字数组,乘以固定权重
[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2]; - 求和 mod 11,对照校验码表
['1','0','X','9','8','7','6','5','4','3','2']; - 注意大小写兼容:
id.toUpperCase().endsWith(checkCode)。
15 位老身份证建议引导升级,或用兼容逻辑转换后再校验。
正则表达式是工具,不是目的。验证逻辑要贴近用户真实输入习惯,错误提示要具体可操作,前后端规则要保持一致。写完记得在 Edge、Safari 和手机浏览器里实测粘贴、自动填充、IME 输入等场景。
技术教程SEO上一篇 : ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
下一篇 : 如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
-
SEO外包最佳选择国内专业的白帽SEO机构,熟知搜索算法,各行业企业站优化策略!
SEO公司
-
可定制SEO优化套餐基于整站优化与品牌搜索展现,定制个性化营销推广方案!
SEO套餐
-
SEO入门教程多年积累SEO实战案例,从新手到专家,从入门到精通,海量的SEO学习资料!
SEO教程
-
SEO项目资源高质量SEO项目资源,稀缺性外链,优质文案代写,老域名提权,云主机相关配置折扣!
SEO资源
-
SEO快速建站快速搭建符合搜索引擎友好的企业网站,协助备案,域名选择,服务器配置等相关服务!
SEO建站
-
快速搜索引擎优化建议没有任何SEO机构,可以承诺搜索引擎排名的具体位置,如果有,那么请您多注意!专业的SEO机构,一般情况下只能确保目标关键词进入到首页或者前几页,如果您有相关问题,欢迎咨询!
别只信