-
Notifications
You must be signed in to change notification settings - Fork 2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
不可思议的CSS导航栏下划线跟随效果 #33
Comments
div:hover {
border-bottom: 1px solid #000;
} 这样? |
@neal1991 你这个没有动画效果 |
@neal1991 |
css 为啥这么难 😢 |
居然给我找到另外一个类似的例子,你也可以一并看看。 |
在这里为什么要使用 before 呢,下划线跟在 li 的后面,为什么不用 after 呢? |
不考虑兼容性的话,完美,主要还是低版本的IE |
从第一个快速移动到第三个 会直接 第一个显示 接着第三个显示 跳过 第二个下划线 |
从效果上看,因为原理不一样,比顺畅跟随的那种效果上还有差距,不过能用css搞定这个很牛逼了! |
还想右到左的又怎么实现, 结果是默认效果 |
你为何如此优秀~~ |
|
右浮动,再用right定位就可以实现从左到右啦 |
赞 |
transition: 0.2s all linear; 这段代码也是相当关键的 其实打了 li:hover ~ li::before { |
css:其实我也没想到还有这种操作 |
如果是背景的话,怎么实现,我尝试了一下,但是从左到右效果不行 |
先上张图,如何使用纯 CSS 制作如下效果?
在继续阅读下文之前,你可以先缓一缓。尝试思考一下上面的效果或者动手尝试一下,不借助 JS ,能否巧妙的实现上述效果。
OK,继续。这个效果是我在业务开发的过程中遇到的一个类似的小问题。其实即便让我借助 Javascript ,我的第一反应也是,感觉很麻烦啊。所以我一直在想,有没有可能只使用 CSS 完成这个效果呢?
定义需求
我们定义一下简单的规则,要求如下:
li
的宽度是不固定的li
移向右侧li
,下划线从左往右移动。同理,当从导航的右侧li
移向左侧li
,下划线从右往左移动。实现需求
第一眼看到这个效果,感觉这个跟随动画,仅靠 CSS 是不可能完成的。
如果想只用 CSS 实现,只能另辟蹊径,使用一些讨巧的方法。
好,下面就借助一些奇技淫巧,使用 CSS 一步一步完成这个效果。分析一下难点:
宽度不固定
第一个难点,
li
的宽度是不固定的。所以,我们可能需要从li
本身的宽度上做文章。既然每个
li
的宽度不一定,那么它对应的下划线的长度,肯定是是要和他本身相适应的。自然而然,我们就会想到使用它的border-bottom
。那么,可能现在是这样子的(li 之间是相连在一起的,li 间的间隙使用
padding
产生):默认隐藏,动画效果
当然,这里一开始都是没有下划线的,所以我们可能需要把他们给隐藏起来。
推翻重来,借助伪元素
这样好像不行,因为隐藏之后,hover
li
的时候,需要下划线动画,而li
本身肯定是不能移动的。所以,我们考虑借助伪元素。将下划线作用到每个li
的伪元素之上。下面考虑第一步的动画,hover 的时候,下划线要从一侧运动展开。所以,我们利用绝对定位,将
li
的伪元素的宽度设置为0,在 hover 的时候,宽度从width: 0 -> width: 100%
,CSS 如下:得到,如下效果:
左移左出,右移右出
OK,感觉离成功近了一步。现在还剩下一个最难的问题:
如何让线条跟随光标的移动动作,实现当从导航的左侧
li
移向右侧li
,下划线从左往右移动。同理,当从导航的右侧li
移向左侧li
,下划线从右往左移动。我们仔细看看,现在的效果:
当从第一个
li
切换到第二个li
的时候,第一个li
下划线收回的方向不正确。所以,可以能我们需要将下划线的初始位置位移一下,设置为left: 100%
,这样每次下划线收回的时候,第一个li
就正确了:看看效果:
额,仔细对比两张图,第二种效果其实是捡了芝麻丢了西瓜。第一个
li
的方向是正确了,但是第二个li
下划线的移动方向又错误了。神奇的 ~ 选择符
所以,我们迫切需要一种方法,能够不改变当前 hover 的
li
的下划线移动方式却能改变它下一个li
的下划线的移动方式(好绕口)。没错了,这里我们可以借助
~
选择符,完成这个艰难的使命,也是这个例子中,最最重要的一环。对于当前 hover 的
li
,其对应伪元素的下划线的定位是left: 100%
,而对于li:hover ~ li::before
,它们的定位是left: 0
。CSS 代码大致如下:至此,我们想要的效果就实现拉!撒花。看看:
效果不错,就是有点僵硬,我们可以适当改变缓动函数以及加上一个动画延迟,就可以实现上述开头里的那个效果了。当然,这些都是锦上添花的点缀。
完整的DEMO可以戳这里: CodePen --Demo
最后
本方法最大的瑕疵在于一开始进入第一个 li 的时候,线条只能是从右往左,除此之外,都能很好的实现跟随效果。
许久没更新了,最近沉迷学习区块链相关技术,譬如以太坊编程,智能合约的编写巴拉巴拉的。后面还是会把更多精力放在本行,多出一些前端文章,CSS 的魅力还是无法抵挡的。
更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。
好了,本文到此结束,希望对你有帮助 :)
如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。
The text was updated successfully, but these errors were encountered: