悬停在 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 秒的主要内容,如果未能解决你的问题,请参考以下文章

markdown 将鼠标悬停在DIV上以扩展宽度

jquery 将鼠标悬停在图像上以交换上面 div 中的另一个图像

将鼠标悬停在按钮上时如何更改 div 的文本?

在悬停时显示一个 DIV,但在另一个悬停的 DIV 内。使用 CSS

如果图像未悬停,则隐藏 div

悬停 div 以在另一个 div 中显示更多内容