没有口水与汗水,就没有成功的泪水。早安!有时,我们以为赢了,其实,我们输了!因为,我们赢了"面子",却输了"里子"!早安!
链接下划线是非常常见的一种样式,最近做了一个非常简单的视觉效果,非常不错,完整代码查看。
XML/HTML Code复制内容到剪贴板
- <!DOCTYPEhtml>
- <html>
- <head>
- <metacharset="gb2312">
- <metaname="viewport"content="width=device-width">
- <title>JSBin</title>
- <style>
- body{
- background-color:#000;
- }
- h2{
- text-align:center;
- margin-top:100px;
- }
- h2>a{
- position:relative;
- color:#FFF;
- text-decoration:none;
- padding-bottom:5px;
- }
- h2>a:hover{
- color:#FFF;
- }
- h2>a:before{
- content:"";
- position:absolute;
- width:100%;
- height:2px;
- bottom:0;
- left:0;
- background-color:#FFF;
- visibility:hidden;
- -webkit-transform:scaleX(0);
- transform:scaleX(0);
- -webkit-transition:all0.3sease-in-out0s;
- transition:all0.3sease-in-out0s;
- }
- h2>a:hover:before{
- visibility:visible;
- -webkit-transform:scaleX(1);
- transform:scaleX(1);
- }
- </style>
- </head>
- <body>
- <h2>
- <arel="nofollow noopener noreferrer" href="/">悬停在我上面</a>
- </h2>
- </body>
- </html>
创建这种效果是非常简单的,不需要添加额外的DOM元素到HTML,不过需要考虑一下浏览器的兼容性问题,在老旧版本的浏览器中它只会显示为一个普通的下划线。
好了,现在正式开始。我们需要做的第一件事就是去除text-decoration,并设置链接为相对定位。我们需要确保链接在hover时不会改变颜色,这里我们拿h2举例:
CSS Code复制内容到剪贴板
- h2>a{
- position:relative;
- color:#000;
- text-decoration:none;
- }
- h2>a:hover{
- color:#000;
- }
接下来,我们要添加border,通过变换隐藏它。插入一个:before并且设置它scaleX(0),保守起见,如果浏览器不支持,我们通过visibility: hidden隐藏它。
CSS Code复制内容到剪贴板
- h2>a:before{
- content:"";
- position:absolute;
- width:100%;
- height:2px;
- bottombottom:0;
- left:0;
- background-color:#000;
- visibility:hidden;
- -webkit-transform:scaleX(0);
- transform:scaleX(0);
- -webkit-transition:all0.3sease-in-out0s;
- transition:all0.3sease-in-out0s;
- }
最后设置动画时间为0.3s,现在我们只需要设置元素在hover时显示并且scaleX(1):
CSS Code复制内容到剪贴板
- h2>a:hover:before{
- visibility:visible;
- -webkit-transform:scaleX(1);
- transform:scaleX(1);
- }
大功告成!
这样就完成了一个很有活力的下划线动画。
本文CSS3绘制有活力的链接下划线到此结束。时间并不会真的帮我们解决什么问题,它只是把原来怎样也想不通的问题,变得不再重要了。小编再次感谢大家对我们的支持!