用::after伪元素实现按钮hover下划线的关键是:按钮设position: relative,::after设absolute定位并用transform: scaleX(0/1)配合transform-origin控制滑动方向,transition实现0.3秒平滑动画。

用 ::after 伪元素实现按钮 hover 时底部滑动下划线,关键是把线条作为绝对定位的子层,从左到右平滑过渡。
确保按钮有相对定位,这样 ::after 才能相对于它定位;线条默认隐藏在左侧,hover 时通过 transform 或 width 动画展开。
position: relative;
::after 设为 position: absolute; bottom: 0; left: 0;
width: 0; 或 transform: scaleX(0);
width: 100%; 或 transform: scaleX(1);
transition: all 0.3s ease; 实现滑动效果相比改变 width,用 scaleX() 触发 GPU 加速,动画更流畅,尤其在移动端。
.btn {
position: relative;
padding: 12px 24px;
background: none;
border: none;
font-size: 16px;
cursor: pointer;
}
.btn::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 2px;
background: #007bff;
transform: scaleX(0);
transform-origin: left;
transition: transform 0.3s ease;
}
.btn:hover::after {
transform: scaleX(1);
}只需改 transform-origin 为 center,再配合 scaleX(0) → scaleX(1),就能实现居中扩散效果。
立即学习“前端免费学习笔记(深入)”;
left: 50%; transform: translateX(-50%) scaleX(0); 初始居中缩为 0transform: translateX(-50%) scaleX(1);
transform-origin: center; 配合 left: 0; 也能生效这个方案在现代浏览器(Chrome/Firefox/Safari/Edge)中完全支持,IE11 也 OK;注意避免在 inline 元素(如 <a></a> 默认)上直接用,建议加 display: inline-block 或 block。
width: 100% 仍有效,线条会贴底铺满容器宽度background 换成 linear-gradient 即可基本上就这些。不复杂但容易忽略定位和 transform-origin 的配合 —— 调对了,线条就听话地滑起来。
以上就是css按钮想在hover时显示底部滑动下划线怎么办_利用::after伪元素打造滑动线条的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号