伪元素::隐藏兄弟元素的内容之前

时间:2017-07-06 17:15:17

标签: html css css3 pseudo-element

我想在将鼠标悬停在我的列表元素上时创建一个过渡效果(或者我的锚标记在这些列表元素中)。

不幸的是,当我使用我创建的转换时,:: before伪元素(或者:: after,我不确定)隐藏了技术上它的兄弟内容,即锚标签中的文本。

我试过操纵ul,li和标签上的z-index无济于事。问题可能在于我使用的位置:在我的过渡中是绝对的,但我不知道我做错了什么。

这是HTML和CSS以及JSFiddle link

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    font-family: 'Open Sans', sans-serif;
}

#headercontainer {
    background-color: #4f2f65;
    height: 125px;
    position: relative;
}

#headercontainer ul {
    height: 100%;
    display: table;
    text-align: center;
    list-style: none;
    margin: 0;
    padding: 0;
}

#sitelogo {
    padding-top: 0px;
}

#headercontainer ul li {
    display: table-cell;
    vertical-align: middle;
    position: relative;
}

#headercontainer ul li a {
    color: #fff;
    font-size: 20px;
    text-decoration: none;
}

a::before {
    content: '';
    display: block;
    height: 0px;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    width: 100%;
    transition: all ease-in-out 200ms;
}

a:hover::before {
    height: 125px;
}

header::after {
    content: '';
    display: table;
    clear: both;
}

#headerlinkslist a:hover {
    color: red;
}

.headerlinks {
    padding-left: 80px;
    padding-right: 80px;
}
<body>
    <header>
        <div id="headercontainer">
            <ul id="headerlinkslist">
                <li id="sitelogo"></li>
                <li><a href="" class="headerlinks">RULES</a></li>
                <li><a href="" class="headerlinks">NEWS</a></li>
                <li><a href="" class="headerlinks">STATS</a></li>
                <li><a href="" class="headerlinks">SUBMIT</a></li>
                <li><a href="" class="headerlinks">LOGIN / REGISTER</a></li>
        </div>
    </header>
</body>

1 个答案:

答案 0 :(得分:3)

向父li提供z-index,然后在伪元素上使用z-index: -1将其推到a后面,但在li之上。

您还需要关闭ul

&#13;
&#13;
html,
body {
  height: 100%;
  margin: 0;
  padding: 0;
  font-family: 'Open Sans', sans-serif;
}

#headercontainer {
  background-color: #4f2f65;
  height: 125px;
  position: relative;
}

#headercontainer ul {
  height: 100%;
  display: table;
  text-align: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

#sitelogo {
  padding-top: 0px;
}

#headercontainer ul li {
  display: table-cell;
  vertical-align: middle;
  position: relative;
  z-index: 1;
}

#headercontainer ul li a {
  color: #fff;
  font-size: 20px;
  text-decoration: none;
  transition: color .25s;
}

a::before {
  content: '';
  display: block;
  height: 0px;
  background-color: #fff;
  position: absolute;
  bottom: 0;
  width: 100%;
  transition: all ease-in-out 200ms;
  z-index: -1;
}

a:hover::before {
  height: 125px;
}

header::after {
  content: '';
  display: table;
  clear: both;
}

#headerlinkslist a:hover {
  color: red;
}

.headerlinks {
  padding-left: 80px;
  padding-right: 80px;
}
&#13;
<body>
  <header>
    <div id="headercontainer">

      <ul id="headerlinkslist">
        <li id="sitelogo"></li>
        <li><a href="" class="headerlinks">RULES</a></li>
        <li><a href="" class="headerlinks">NEWS</a></li>
        <li><a href="" class="headerlinks">STATS</a></li>
        <li><a href="" class="headerlinks">SUBMIT</a></li>
        <li><a href="" class="headerlinks">LOGIN / REGISTER</a></li>

       </ul>
    </div>

  </header>
</body>
&#13;
&#13;
&#13;