我想要实现的目标非常简单,但我想我不明白它是如何运作的。我想在悬停时从左到右出现一个边框顶部。
我几次尝试不成功..它只是出现但不是我想要的方式。我有的最后一个是这个:
#navHead li {
list-style: none;
display: inline-block;
margin-left: 1em;
}
.slideBorder {
text-decoration: none;
text-transform: uppercase;
color: #7f7f7f;
padding: 0.5em;
border-top: 2px solid transparent;
width: 0px;
-webkit-transition: 1s ease;
-moz-transition: 1s ease;
-o-transition: 1s ease;
o-transition: 1s ease;
}
.slideBorder:hover {
border-top: 2px solid #1fda9a;
width: 100%;
}

<ul id="navHead">
<li><a class="slideBorder" href="#">hi</a>
</li>
<li><a class="slideBorder" href="#">hi</a>
</li>
<li><a class="slideBorder" href="#">hi</a>
</li>
</ul>
&#13;
有人可以帮我吗?
由于
答案 0 :(得分:3)
你不能真正为这样的边框设置动画,但你可以使用伪元素。
#navHead li {
list-style: none;
display: inline-block;
margin-left: 1em;
}
.slideBorder {
text-decoration: none;
text-transform: uppercase;
color: #7f7f7f;
padding: 0.5em;
position: relative;
}
.slideBorder:after {
content: '';
position: absolute;
top: 0;
left: 0;
width: 0;
height: 3px;
background: #f00;
transition: width 0.5s ease;
}
.slideBorder:hover:after {
width: 100%;
}
<ul id="navHead">
<li><a class="slideBorder" href="#">hi</a>
</li>
<li><a class="slideBorder" href="#">hi</a>
</li>
<li><a class="slideBorder" href="#">hi</a>
</li>
</ul>