CSS :invalid 伪类可自动为校验失败的表单控件添加样式,需配合 required、type="email"、min/max、pattern 等约束属性生效;注意初始空值即触发问题,推荐用 .touched 类或 :user-invalid 延迟提示,并结合 JS 或 ARIA 提供错误文案。

可以利用 CSS 的 :invalid 伪类自动为校验失败的表单控件添加提示样式,无需 JavaScript 干预,但需注意其触发条件和局限性。
:invalid 只在元素存在内置校验(如 required、type="email"、min/max、pattern 等)且当前值不满足时生效。没有校验属性的输入框即使为空也不会被识别为 :invalid。
required 属性:red>type="email":ail" required>min="1" max="100",或自定义格式加 pattern="[0-9]{6}"
直接为 :invalid 定义边框、背景或图标等样式,让用户一眼识别问题项:
input:invalid { border-color: #e53e3e; }
input:invalid { background-color: #fff5f5; }
input:invalid::after { content: "⚠"; color: #e53e3e; margin-left: 4px; }(注意:::after 对 <input> 无效,可改用父容器 + ::before 或额外 <span></span>)默认情况下,页面加载后空的 required 输入框会立即显示 :invalid 样式,影响体验。可通过结合 :user-invalid(现代浏览器支持)或 JS 控制 class 来延迟提示:
立即学习“前端免费学习笔记(深入)”;
:invalid 样式,监听 blur 或 submit 后给表单加 .touched 类,再写 .touched input:invalid
input:user-invalid 替代 :invalid,它只在用户编辑过且值非法时触发(Chrome 102+、Firefox 119+、Safari 16.4+ 支持):invalid 仅控制样式,无法生成文字提示。若需显示“邮箱格式不正确”这类消息,仍需:
<span class="error"></span>,用 JS 在 checkValidity() 为 false 时填入提示aria-invalid="true" 和 aria-describedby 关联错误区域,提升可访问性form.checkValidity(),统一高亮并提示以上就是css表单校验失败需要提示样式怎么办_利用:invalid伪类自动标记错误的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号