悬停在 div(1) 上以显示 div(2),如果 mouseout 继续显示 div(2) x 秒
Posted
技术标签:
【中文标题】悬停在 div(1) 上以显示 div(2),如果 mouseout 继续显示 div(2) x 秒【英文标题】:Hover on div(1) to show div(2), if mouseout continue to show div(2) for x seconds 【发布时间】:2015-04-08 07:48:56 【问题描述】:当我将鼠标悬停在图像上时,会出现 div(2)。 但我希望 div(2) 即使在鼠标移出时也能保持大约 x 秒。
我只想使用纯 CSS。 我该怎么做?
jsFiddle
#basarilar
float: right;
margin: 7px 357px;
width: 140px;
height: 24px;
position: relative;
z-index: 9999;
.yildiz
height: 24px;
width: 24px;
background: url("http://www.kelimelerbenim.com/wp-content/themes/kelimelerbenim/images/yildiz.png") 0 0 no-repeat;
margin-left: 10px;
float: right;
transition: .50s all;
transition-delay: 5s;
.yildiz:hover
background: url("http://www.kelimelerbenim.com/wp-content/themes/kelimelerbenim/images/yildiz-2.png") 0 0 no-repeat;
.aciklama
display: none;
position: absolute;
width: 200px;
height: 70px;
z-index: 9999;
top: 48px;
right: 0px;
padding: 15px 15px;
font-weight: bold;
text-align: center;
#bumerang1
color: #ffffff;
background: #76ab01;
#bumerang:hover + #bumerang1
display: block;
#bumerang1:hover
display: block;
<div id="basarilar">
<div id="bumerang" class="yildiz"></div>
<div id="bumerang1" class="aciklama">This is my DIV</div>
</div>
【问题讨论】:
【参考方案1】:Christopher Pearson 关于使用转换延迟是正确的,但您还需要更改其他一些东西。
#basarilar
float:right;
margin:7px 357px;
width: 140px;
height: 24px;
position: relative;
z-index: 9999;
.yildiz
height:64px;
width:64px;
background:url("http://i.stack.imgur.com/vNQ2g.png?s=64&g=1") no-repeat;
margin-left:10px;
float:right;
transition: .50s all;
transition-delay: 5s;
.yildiz:hover
background:url("http://i.stack.imgur.com/vNQ2g.png?s=64&g=1") 0 0 no-repeat;
.aciklama
visibility: hidden; /* use visibility rather than display */
position:absolute;
width: 200px;
height: 70px;
z-index: 9999;
top:48px;
right:0px;
padding: 15px 15px;
font-weight: bold;
text-align: center;
transition-delay: 3s; /* Set transition-delay to 3s, so the mouse out is delayed */
#bumerang1
color:#ffffff;
background: #76ab01;
#bumerang:hover + #bumerang1
visibility: visible; /* use visibility rather than display */
transition-delay: 0s; /* Set transition-delay to 0s, so the mouse over is still immediate */
#bumerang1:hover
display:block;
<div id="basarilar">
<div id="bumerang" class="yildiz"></div>
<div id="bumerang1" class="aciklama">This is my DIV</div>
</div>
【讨论】:
【参考方案2】:您必须使用带有.transition-duration
的转换。有关类似应用程序,请参阅this thread。您还可以查看 W3 学校过渡页面here。
【讨论】:
以上是关于悬停在 div(1) 上以显示 div(2),如果 mouseout 继续显示 div(2) x 秒的主要内容,如果未能解决你的问题,请参考以下文章
jquery 将鼠标悬停在图像上以交换上面 div 中的另一个图像