css3 border-top在悬停时从左侧出现

时间:2015-07-25 19:27:30

标签: html css list css3 nav

我想要实现的目标非常简单,但我想我不明白它是如何运作的。我想在悬停时从左到右出现一个边框顶部。

我几次尝试不成功..它只是出现但不是我想要的方式。我有的最后一个是这个:



#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;
&#13;
&#13;

有人可以帮我吗?

由于

1 个答案:

答案 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>