为了账号安全,请及时绑定邮箱和手机立即绑定

使用 .animate 淡出 .mouseout 的过渡?

使用 .animate 淡出 .mouseout 的过渡?

梦里花落0921 2024-01-11 17:29:27
我有一个 div,当你悬停时,另一个 div 会出现。它们不是父/子或包装的,所以我使用了一个脚本来让它尽可能简单地工作并获得我需要的东西。随着 .mouseover ,悬停 div 慢慢出现,这就是我想要的。我的问题是让 .mouseout 使悬停 div 慢慢消失并保持消失。我尝试过不同的变化,但最接近的是让 div 慢慢消失,但在我设置的延迟后它会弹出。我对js很陌生,真的没有任何经验。我编写了该代码的第一部分,该代码可以工作,但 .mouseout 是我遇到的问题。这是我的代码:$("#show_stats1 h1").mouseover(function() { $(".stat-1_info").css({opacity: 0.0, visibility: "visible"}).animate({opacity: 1}, 200); });$("#show_stats1 h1").mouseout(function() { $(".stat-1_info").css({opacity: 0.0, visibility: "hidden"}).animate({opacity: 1}, 200); });我知道这可能很简单,但我对 js 不太了解。这是 HTML:<div id="show_stats1" class="stats">    main, visible div</div><div class="stat-1_info" style="visibility:hidden;">    hidden div to be shown on hover</div>这是一个jsfiddle https://jsfiddle.net/yt3h9xnf/
查看完整描述

1 回答

?
拉丁的传说

TA贡献1789条经验 获得超8个赞

您可以将该.animate()方法与opacity或 一起使用visibility。没有理由同时使用两者。

$("#show_stats1 h1").mouseover(function() { 

  $(".stat-1_info").animate({opacity: 1}, 200);

});


$("#show_stats1 h1").mouseout(function() { 

  $(".stat-1_info").animate({opacity: 0}, 200);

});

.stat-1_info {

  opacity: 0;

}

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>


<div id="show_stats1" class="stats">

    <h1>main, visible div</h1>

</div>


<div class="stat-1_info">

    hidden div to be shown on hover

</div>


查看完整回答
反对 回复 2024-01-11
?
摇曳的蔷薇

TA贡献1793条经验 获得超6个赞

  1. fadeIn()通过使用andfadeOut()作为sec参数使其变得简单。这将照顾您想要看到文本并想要消失的时间。

  2. 使用display:none;现在市场上最新、最好的而不是使用visibility房产。

淡入()

消退()

$(document).ready(function() {

  $("#show_stats1 h1").mouseover(function() {

    $(".stat-1_info").fadeIn(3000); // Choose your own time(3sec)

  });


  $("#show_stats1 h1").mouseout(function() {

    $(".stat-1_info").fadeOut(2000); // Choose your own time(2sec)

  });

});

.stats_container {

  width: 310px;

  padding: 10px;

  margin-bottom: 0px;

}


.stats {

  width: 300px;

  height: 34px;

  margin: 15px 0px -3px 0px;

}


.stats h1 {

  text-align: left;

}


.stats h2 {

  position: absolute;

  left: 260px;

  margin-top: 8px;

  width: 50px;

  text-align: right;

}


.stats h1 {

  display: inline-block;

  font-weight: 400;

  color: #000;

  line-height: 9.5pt;

  font-size: 9.5pt;

}


.stat-1_info {

  top: -50px;

  margin: 0px;

}


.stat-1_info {

  float: right;

  position: relative;

  left: 0px;

  display: inline-block;

  width: 380px;

  height: 334px;

  background: red;

}

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<div class="stats_container">

  <div id="show_stats1" class="stats">

    <h1>Strength:</h1>

  </div>

</div>



<div class="stat-1_info" style="display:none;">

  Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam pretium magna et velit dignissim, a placerat nisi rutrum. Vestibulum odio ipsum, rutrum a ex ac, fringilla fermentum ante. Donec nec elit molestie massa finibus pulvinar non nec lacus. Nullam

  ipsum nulla, sodales non ornare et, accumsan a sem. Donec tempus leo non laoreet viverra. Vestibulum ac nunc sem. Aenean vitae convallis velit, non molestie augue. Curabitur tristique eleifend mi, malesuada fringilla erat tristique imperdiet.

</div>


查看完整回答
反对 回复 2024-01-11
  • 1 回答
  • 0 关注
  • 151 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信