传递给另一个元素时动画伪元素

时间:2014-03-10 14:42:38

标签: css css3 pseudo-element

我有一个伪元素,用于在导航栏中标记用户当前的选择。它是一个小的向上三角形,一个Font-Awesome的图标字体。 here's a jsFiddle DEMO它(您需要拉伸结果面板,以便所有内容都有衬里)。

enter image description here

.subnav > ul > li.active > a:after {
  position: relative;
  text-align: center;
  font-family: FontAwesome;
  top: 25px;
  right: 50%;
  content: "\f0de";
  color: #c1c1c1;
}

我添加了一些基本的jQuery函数来切换.active类,我想知道是否有一种方法可以设置伪元素的转换动画,以便它可以水平移动到新位置。

我知道伪元素过渡是一件事,但搜索和谷歌搜索我找不到任何类似于我正在寻找的东西。这甚至可能吗?

1 个答案:

答案 0 :(得分:2)

在这个解决方案中,我使用:target伪类来切换状态,但我建议你坚持使用切换.active类的jQuery函数。

<强> FIDDLE

标记

<div class="page" id="one">page one</div>
<div class="page" id="two">page two</div>
<div class="page" id="three">page three</div>

<div class="top">
    <div class="arrow"></div>
    <ul>
        <li><a href="#one">One</a></li>
        <li><a href="#two">Two</a></li>
        <li><a href="#three">Three</a></li>
    </ul>
</div>

CSS

.top
{
    background: #eee;   
    position:relative;
    overflow: hidden;  
}
.arrow
{
    border-bottom: 1px solid #c2c2c2;
    height: 50px;

}
.arrow:before
{
    content: '';
    display: block;
    width: 14px;
    height: 14px;
    border: 1px solid #c2c2c2;
    border-radius: 3px;
    position:absolute;
    bottom:-9px;
    left: 30px;
    background: #fff;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg); 
    transform: rotate(45deg);

    -webkit-transition: left, 0.5s;
    -moz-transition: left, 0.5s;
    -o-transition: left, 0.5s;
    transition: left, 0.5s;
}
ul
{
    position: absolute;
    top: 0;
    list-style: none;
    padding-left: 20px;
    margin-top: 15px;
}
li
{
    display: inline-block;
    text-decoration: none;
    font-size: 18px;
    color: #676767;
    margin-right: 40px;
}
.page
{
    width: 100%;
    height: 200px;
    position: absolute;
    top: 80px;
    opacity: 0;
    background: yellow;
    -webkit-transition: opacity, 0.5s;
    -moz-transition: opacity, 0.5s;
    -o-transition: opacity, 0.5s;
    transition: opacity, 0.5s;
}
.page:target
{
    opacity: 1;
}

#two
{
    background: pink;
}
#three
{
    background: brown;
}
#one:target ~ .top .arrow:before
{
    left: 30px;
}
#two:target ~ .top .arrow:before
{
    left: 105px;
}
#three:target ~ .top .arrow:before
{
    left: 189px;
}