CSS:在悬停时显示并同时隐藏不同的div?

时间:2013-06-30 17:56:28

标签: css css3

这是CSS示例如何显示隐藏的div(悬停时):

<div class="showhim">HOVER ME<div class="showme">hai</div></div>

.showme{ 
display: none;
}
.showhim:hover .showme{
display : block;
}

我可以使用仅限CSS 显示一个div并同时隐藏另一个 吗? 以下是如何使用JS实现此目的的示例:http://jsfiddle.net/joshvito/GaZQ6/

3 个答案:

答案 0 :(得分:89)

http://jsfiddle.net/MBLZx/

这是代码

 .showme{ 
   display: none;
 }
 .showhim:hover .showme{
   display : block;
 }
 .showhim:hover .ok{
   display : none;
 }
 <div class="showhim">
     HOVER ME
     <div class="showme">hai</div>
     <div class="ok">ok</div>
</div>

   

答案 1 :(得分:11)

如果另一个div是兄弟姐妹/孩子,或父母的任何组合,是

    .showme{ 
        display: none;
    }
    .showhim:hover .showme{
        display : block;
    }
    .showhim:hover .hideme{
        display : none;
    }
    .showhim:hover ~ .hideme2{ //~ sibling selector
        display:none;
    }
    <div class="showhim">
        HOVER ME
        <div class="showme">hai</div> 
        <div class="hideme">bye</div>
    </div>
    <div class="hideme2">bye bye</div>

答案 2 :(得分:1)

你尝试过这样的事吗?

.showme{display: none;}
.showhim:hover .showme{display : block;}
.hideme{display:block;}
.showhim:hover .hideme{display:none;}

<div class="showhim">HOVER ME
  <div class="showme">hai</div>
  <div class="hideme">bye</div>
</div>

我不知道为什么不可能这样做。