0

0

修复 HTML 表单 required 属性失效问题:正确绑定表单提交验证

花韻仙語

花韻仙語

发布时间:2026-02-15 13:12:10

|

396人浏览过

|

来源于php中文网

原创

修复 HTML 表单 required 属性失效问题:正确绑定表单提交验证

HTML 表单中 required 属性仅在表单提交(submit)时触发浏览器原生验证,若通过按钮 click 事件跳转页面而未真正提交表单,验证将被绕过。解决方法是监听 form 的 submit 事件,并阻止默认行为后再执行逻辑。

html 表单中 required 属性仅在表单提交(submit)时触发浏览器原生验证,若通过按钮 click 事件跳转页面而未真正提交表单,验证将被绕过。解决方法是监听 form 的 submit 事件,并阻止默认行为后再执行逻辑。

在您提供的登录页代码中, 元素已正确添加 required 属性,且 type="email" 和 type="password" 也符合语义化要求——这本身没有问题。但关键缺陷在于:两个按钮(Login 和 Signup)均通过 click 事件直接调用 window.location.href 跳转,完全绕过了表单提交流程。因此,浏览器根本没有机会触发 required 验证,导致“必填校验失效”。

✅ 正确做法是:统一监听

元素的 submit 事件
,根据提交按钮的 name 或 id 判断用户意图,并在验证通过后执行对应跳转。

以下是修复后的完整代码(关键修改已高亮说明):

上班人导航
上班人导航

上班人必备的职场办公导航网站

下载
<form id="loginForm">
  <label for="email">Email</label>
  <input type="email" id="email" name="email" required placeholder="your@example.com">

  <label for="password">Password</label>
  <input type="password" id="password" name="password" required placeholder="••••••••">

  <!-- 为按钮添加 name 属性以便区分提交意图 -->
  <button type="submit" name="action" value="login" id="my2Button">Login</button>

  <div id="text1" style="text-align: center; margin: 12px 0;">or if you don't have an account</div>

  <button type="submit" name="action" value="signup" id="myButton">Signup</button>
</form>

<script>
  const form = document.getElementById('loginForm');

  form.addEventListener('submit', function (e) {
    e.preventDefault(); // ✅ 关键:阻止默认提交(否则页面会刷新或跳转到空URL)

    // 获取触发提交的按钮值
    const submitBtn = e.submitter;
    const action = submitBtn?.value;

    // 浏览器原生验证在此刻生效(自动检查 required、email 格式等)
    if (!form.checkValidity()) {
      // 若验证失败,浏览器会显示默认提示(如 "Please fill in this field")
      return;
    }

    // 验证通过后,按需跳转
    if (action === 'login') {
      window.location.href = 'payement.html';
    } else if (action === 'signup') {
      window.location.href = 'Signup.html';
    }
  });
</script>

? 重要说明与最佳实践:

立即学习前端免费学习笔记(深入)”;

  • e.preventDefault() 不可省略:它阻止表单默认提交行为(如 GET 请求到当前 URL),确保我们能自主控制后续逻辑;
  • 使用 e.submitter 获取点击的按钮:现代浏览器支持该属性,精准识别用户是点了 Login 还是 Signup(兼容性良好,Chrome 58+/Firefox 76+/Edge 79+);
  • 保留 required + type="email":它们仍发挥核心作用——只要触发 submit,浏览器就会自动校验并聚焦错误字段;
  • 避免多个 type="submit" 按钮共用同一表单却无区分逻辑:否则无法判断用户意图,易引发误跳转;
  • 增强健壮性(可选):可补充 form.addEventListener('invalid', ...) 自定义错误提示,或用 setCustomValidity() 实现更灵活的验证规则。

? 总结:required 不是“点击即校验”,而是“提交时校验”。把交互逻辑从 button.click 迁移到 form.submit,既修复了验证失效问题,也符合 HTML 表单设计规范,是前端表单开发的基石原则。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

946

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

779

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1561

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

390

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

982

2025.04.24

location.assign
location.assign

在前端开发中,我们经常需要使用JavaScript来控制页面的跳转和数据的传递。location.assign就是JavaScript中常用的一个跳转方法。通过location.assign,我们可以在当前窗口或者iframe中加载一个新的URL地址,并且可以保存旧页面的历史记录。php中文网为大家带来了location.assign的相关知识、以及相关文章等内容,供大家免费下载使用。

231

2023.06.27

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.11.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

49

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

AngularJS教程
AngularJS教程

共24课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 32万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号