css链接悬停时滑动的下划线效果

J.sky
CSS
2023/5/7

要创建链接悬停时滑动的下划线效果,可以向锚点标记添加伪元素,并使用 CSS 过渡动画来显示它。

先看效果:

<style> .boxhaha{ display: flex; } a { margin: 0 5px; position: relative; text-decoration: none; } a::after{ content: ''; z-index: -1; position: absolute; background-color: #44ce7b; width: 100%; height: 10%; bottom: -2px; left: 0; visibility: hidden; transform: scaleX(0); transition: transform 200ms ease-in-out; } a:hover::after{ visibility: visible; transform: scaleX(1); } </style> <div class="boxhaha"> <a href="#">linklink</a> <a href="#">linklink</a> <a href="#">linklink</a> <a href="#">linklink</a> </div>

在提供的代码中,a::after 选择器创建了一个伪元素,该伪元素位于 a 标记后面。该伪元素具有绿色背景颜色和 10%锚的高度。它相对于链接绝对定位并最初使用 visibility:hidden 隐藏,使它不会在链接悬停之前出现。

当链接悬停时,a:hover::after 选择器更改 visibility 和 transform 属性,使伪元素变为可见并水平缩放以匹配锚点标记的宽度。为了使动画平滑,a::after 选择器上定义了 transition 属性,以指定动画的持续时间和缓动功能。

通过组合这些 CSS 属性,当用户悬停在链接上时创建了一个滑动下划线效果。

代码如下:

<style>
        .boxhaha{
            display: flex;
        }
        a {
            margin: 0 5px;
            position: relative;
            text-decoration: none;
        }
        a::after{
            content: '';
            z-index: -1;
            position: absolute;
            background-color: #44ce7b;
            width: 100%;
            height: 10%;
            bottom: -2px;
            left: 0;
            visibility: hidden;
            transform: scaleX(0);
            transition: transform 200ms ease-in-out;
        }
        a:hover::after{
            visibility: visible;
            transform: scaleX(1);
        }
</style>
<div class="boxhaha">
    <a href="#">linklink</a>
    <a href="#">linklink</a>
    <a href="#">linklink</a>
    <a href="#">linklink</a>
</div>