0

0

如何使用纯 CSS 实现按钮悬停添加阴影、点击时移除阴影效果

碧海醫心

碧海醫心

发布时间:2026-01-31 09:57:10

|

712人浏览过

|

来源于php中文网

原创

如何使用纯 CSS 实现按钮悬停添加阴影、点击时移除阴影效果

无需 javascript,仅用 :hover:not(:active) 伪类组合即可优雅实现鼠标悬停时添加样式、按下时不生效的效果,兼顾语义性、性能与可维护性。

在 Web 开发中,常需为按钮添加“悬停高亮”或“按压反馈”等交互效果。一个典型需求是:鼠标移入时添加阴影(如 box-shadow),而鼠标按下(mousedown)时立即移除该效果——这看似需要 JS 监听事件并操作 class,实则可通过纯 CSS 更简洁、高效地完成。

✅ 推荐方案:纯 CSS 伪类组合

利用 CSS 的状态伪类逻辑,直接使用:

.btn:hover:not(:active) {
  box-shadow: 5px 5px darkgoldenrod;
}

该规则含义明确:

网易人工智能
网易人工智能

网易数帆多媒体智能生产力平台

下载
  • :hover → 鼠标指针位于元素上方时匹配;
  • :not(:active) → 排除当前处于激活态(即鼠标按键被按下)的时刻;
  • 组合后效果即为:仅在悬停且未按下时生效,一旦用户点击按钮,:active 状态触发,:hover:not(:active) 立即不匹配,阴影自动消失——完美契合需求。

? 为什么不应使用原 JS 方案?

原始代码存在多个问题:

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

  • ❌ 内联事件(onmouseover="result(1)")破坏 HTML 与行为分离原则;
  • ❌ result(1) 中硬编码索引 n=1,缺乏健壮性,无法适配多按钮场景;
  • ❌ onmouseover/onmousedown 被重复赋值,且内部嵌套循环遍历所有按钮,逻辑冗余且易出错;
  • ❌ 未考虑 mouseleave 或 mouseup 等边界情况,状态易失控;
  • ❌ 违背“渐进增强”理念:CSS 能胜任的交互,优先交由 CSS 处理,更轻量、更可靠、更利于无障碍访问。

✅ 正确的 HTML + CSS 结构示例

Navigating the digital landscape for success

Our digital marketing agency helps businesses grow and succeed online through a range of services including SEO, PPC, social media marketing, and content creation.
.btn {
  width: 231px;
  height: 68px;
  border-radius: 14px;
  border: 1px solid #191A23;
  background-color: #fff;
  color: #000;
  font-size: 20px;
  padding: 0;
  cursor: pointer; // 显式声明可交互性,提升 UX

  &_prev {
    color: #fff;
    background-color: #191A23;
    width: 264px;
  }
}

// ✅ 核心交互样式:悬停有阴影,按下时无阴影
.btn:hover:not(:active) {
  box-shadow: 5px 5px darkgoldenrod;
}

// (可选)增强体验:添加 :active 状态反馈
.btn:active {
  transform: translateY(2px); // 模拟按压下沉
  box-shadow: none;
}

? 补充说明与最佳实践

  • 兼容性::hover:not(:active) 在所有现代浏览器(Chrome、Firefox、Safari、Edge)及 IE9+ 中均被完整支持;
  • 移动端注意:在触摸设备上,:hover 可能延迟触发或行为不一致,建议搭配 @media (hover: hover) 做条件启用,或统一使用 :focus-visible 增强键盘可访问性;
  • 性能优势:CSS 伪类由渲染引擎原生处理,零 JS 执行开销,无重排重绘风险;
  • 可维护性:样式逻辑集中于 CSS,便于设计系统统一管理、主题切换与 A/B 测试。
✅ 总结:面对“悬停添加类、点击移除类”的需求,请优先思考是否可用 CSS 伪类组合解决。本例中,hover:not(active) 是语义清晰、性能卓越、书写简洁的标准解法——让 CSS 做它最擅长的事,把 JS 留给真正需要逻辑判断的场景。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

841

2023.08.11

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

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

746

2023.11.06

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

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

1445

2023.08.21

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

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

382

2024.03.05

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

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

945

2025.04.24

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

469

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.12.06

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

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

515

2023.06.20

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

33

2026.01.30

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25.6万人学习

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

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