在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
国服第一切图仔 github.com/chokcoco 先上张图,如何使用纯 CSS 制作如下效果? 在继续阅读下文之前,你可以先缓一缓。尝试思考一下上面的效果或者动手尝试一下,不借助 JS ,能否巧妙的实现上述效果。 OK,继续。这个效果是我在业务开发的过程中遇到的一个类似的小问题。其实即便让我借助 Javascript ,我的第一反应也是,感觉很麻烦啊。所以我一直在想,有没有可能只使用 CSS 完成这个效果呢? 定义需求 我们定义一下简单的规则,要求如下: 假设 HTML 结构如下: <ul> <li>不可思议的CSS</li> <li>导航栏</li> <li>光标小下划线跟随</li> <li>PURE CSS</li> <li>Nav Underline</li> </ul>
实现需求 第一眼看到这个效果,感觉这个跟随动画,仅靠 CSS 是不可能完成的。 如果想只用 CSS 实现,只能另辟蹊径,使用一些讨巧的方法。 好,下面就借助一些奇技淫巧,使用 CSS 一步一步完成这个效果。分析一下难点: 宽度不固定 第一个难点, 既然每个 li { border-bottom: 2pxsolid#000; } 那么,可能现在是这样子的(li 之间是相连在一起的,li 间的间隙使用 当然,这里一开始都是没有下划线的,所以我们可能需要把他们给隐藏起来。 li { border-bottom: 0pxsolid#000; } 推翻重来,借助伪元素 这样好像不行,因为隐藏之后,hover li::before { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-bottom: 2pxsolid#000; } 下面考虑第一步的动画,hover 的时候,下划线要从一侧运动展开。所以,我们利用绝对定位,将 li::before { content: ""; position: absolute; top: 0; left: 0; width: 0; height: 100%; border-bottom: 2pxsolid#000; } li:hover::before { width: 100%; } 得到,如下效果: OK,感觉离成功近了一步。现在还剩下一个最难的问题: 如何让线条跟随光标的移动动作,实现当从导航的左侧 我们仔细看看,现在的效果: 当从第一个 li::before { content: ""; position: absolute; top: 0; left: 100%; width: 0; height: 100%; border-bottom: 2pxsolid#000; } li:hover::before { left: 0; width: 100%; } 看看效果: 额,仔细对比两张图,第二种效果其实是捡了芝麻丢了西瓜。第一个 所以,我们迫切需要一种方法,能够不改变当前 hover 的 没错了,这里我们可以借助 对于当前 hover 的 li::before { content: ""; position: absolute; top: 0; left: 100%; width: 0; height: 100%; border-bottom: 2pxsolid#000; transition: 0.2salllinear; } li:hover::before { width: 100%; left: 0; } li:hover~li::before { left: 0; } 至此,我们想要的效果就实现拉!撒花。看看: 效果不错,就是有点僵硬,我们可以 适当改变缓动函数 以及加上一个 动画延迟 ,就可以实现上述开头里的那个效果了。当然,这些都是锦上添花的点缀。 完整的DEMO可以戳这里: CodePen --Demo 最后 本方法 最大的瑕疵 在于一开始进入第一个 li 的时候,线条只能是从右往左,除此之外,都能很好的实现跟随效果。 许久没更新了,最近沉迷学习区块链相关技术,譬如以太坊编程,智能合约的编写巴拉巴拉的。后面还是会把更多精力放在本行,多出一些前端文章,CSS 的魅力还是无法抵挡的。 更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。 总结 以上所述是小编给大家介绍的不可思议的CSS导航栏下划线跟随效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对极客世界网站的支持!
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论