0

0

css:focus伪类与:active伪类区别_为表单元素实现不同交互状态

P粉602998670

P粉602998670

发布时间:2026-02-05 11:41:28

|

276人浏览过

|

来源于php中文网

原创

:focus 在元素获得焦点时生效,与鼠标动作无关;:active 在鼠标/触控按下瞬间触发且瞬态存在;二者触发条件正交、生命周期不同,常共存于表单交互。

css:focus伪类与:active伪类区别_为表单元素实现不同交互状态

:focus 只在获得焦点时触发,不依赖鼠标动作

用户用 Tab 键切换、点击输入框、或调用 element.focus() 时,:focus 就会生效。它和鼠标是否按下完全无关——哪怕鼠标悬停但没点,只要元素有焦点,样式就显示。常见于表单校验提示、键盘导航高亮等场景。

注意::focus 在移动端可能行为受限(比如 iOS Safari 默认不给非可交互元素加 focus 样式),需配合 tabindex="0" 或确保元素原生可聚焦(如 )。

  • input:focus 通常用于加边框阴影或背景微调,提示“当前正在编辑”
  • 若同时定义了 :hover:focus,鼠标悬停后点击会先触发 :hover,再叠加 :focus;松开鼠标后 :hover 消失,:focus 仍保留
  • 避免仅靠颜色变化实现 :focus 样式,需满足 WCAG 对比度和视觉辨识要求

:active 在鼠标/触控按下瞬间触发,松开即消失

:active 是瞬态伪类:从鼠标左键按下去那一刻开始,到松开为止,样式才生效。它不关心焦点,也不等待元素是否可交互——哪怕一个

加了 :active,点击它也会触发(尽管没实际交互逻辑)。

典型用途是按钮按下的视觉反馈,比如缩放、变色、位移。但它无法用于键盘操作(Tab 进入不会触发 :active)。

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

玄鲸Timeline
玄鲸Timeline

一个AI驱动的历史时间线生成平台

下载
  • button:active 常配合 transform: scale(0.98)background-color 暗化,模拟“被按下”感
  • 在触摸设备上,:active 持续时间极短(约 100–300ms),且默认可能被禁用,需在 中加 并确保无 -webkit-tap-highlight-color: transparent 干扰
  • 不要用 :active 替代 :focus 来做可访问性焦点指示——它不持久,屏幕阅读器用户无法感知

表单中两者常共存,但作用域和生命周期完全不同

比如一个搜索框:input[type="search"] 获得焦点时显示蓝色描边(:focus),而用户点击右侧清空按钮时,按钮短暂下陷(:active)。它们互不干扰,因为触发条件正交:一个是“谁在编辑”,一个是“谁正被按着”。

  • 顺序很重要:CSS 中 :active 应写在 :focus 后面,否则聚焦状态下点击可能看不到按下效果(层叠优先级相同,后声明者胜出)
  • :focus-visible 是更现代的替代方案,能区分键盘 focus 和鼠标 click,避免鼠标用户看到多余焦点环;但兼容性需查 Can I Use
  • 某些框架(如 React)中,手动调用 ref.current.focus() 不会触发 :active,因为没真实鼠标事件,这点容易误以为样式失效

别混淆 :active 和 JavaScript 的 mousedown / click 事件

CSS :active 是纯样式响应,不产生事件、不阻塞主线程、也不可编程控制持续时间。而 JS 的 mousedown 可以做防抖、取消默认行为、甚至阻止 :active 触发(比如 e.preventDefault() 在某些浏览器下会影响)。

  • 如果需要“长按触发”或“按住持续执行”,必须用 JS,:active 无法做到
  • contenteditable 元素或自定义组件上,:focus 行为可能不稳定,建议用 document.activeElement + 类名切换来兜底
  • 测试时别只靠鼠标点——用 Tab 切换验证 :focus,用真机触摸验证 :active 是否及时响应
真正难的是让两者在不同输入方式下都自然:键盘用户不想要突兀的 :active,触摸用户又讨厌延迟的 :focus 反馈。细节都在事件流和平台默认行为里,而不是一行 CSS 能解决的。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

589

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

589

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

516

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

307

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

381

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5446

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

483

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

213

2023.09.04

AO3官网入口与镜像站汇总 Archive of Our Own访问路径及最新入口
AO3官网入口与镜像站汇总 Archive of Our Own访问路径及最新入口

本专题专注于提供Archive of Our Own (AO3) 的最新官网入口与镜像站地址,详细整理了可用的访问路径,包括中文镜像站入口和网页版直达链接,帮助用户轻松找到最稳定的访问方式,确保顺畅浏览AO3内容。

1

2026.02.05

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

CSS教程
CSS教程

共754课时 | 27.6万人学习

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

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