jquery用CSS过渡效果隐藏div

时间:2015-05-17 18:57:36

标签: javascript jquery css css3

我有一个关于使用jquery hide函数进行CSS隐藏转换的问题。

我已从codepen.io

创建了 DEMO

在此演示中,您可以看到显示按钮。单击“显示”按钮,然后.test.user-image div打开CSS过渡效果。

我想点击隐藏按钮然后.test div隐藏CSS转换效果。

任何人都可以告诉我一个小例子我该怎么做?

CSS

<div class="container">
  <div class="usr">Show</div>
  <div class="test">
    <div class="hide">Hide</div>
    <div class="user-image" style="background-image:url(...);"></div>
  </div>

</div>

JS

$(document).ready(function() {
  $('.usr').click(function() {
   $(".test").show();
  });
  $(".hide").click(function() {
    $(".test").hide();
  });
});

4 个答案:

答案 0 :(得分:5)

你根本不需要jQuery。检查此示例:

http://codepen.io/anon/pen/JdKWWW

&#13;
&#13;
.hide-show-element {
  background-color: #eee;
  height: 400px;
  position: relative;
  text-align: center;
  width: 400px;
}

.hide-show-element input[type='checkbox'] {
  display: none;
}
.hide-show-element label {
  background-color: #a00;
  border: 1px solid #111;
  color: #fff;
  display: block;
  text-align: center;
  transition-duration: 0.4s;
}
.hide-show-element label:after {
  display: block;
  content: "Show";
}
.hide-show-element input:checked + label {
  background-color: #fff;
  border: 1px solid #a00;
  color: #a00;
}
.hide-show-element input:checked + label:after {
  content: "Hide";
}

.test1 {
  opacity: 0;
  position: relative;
  height: 0;
  top: 20%;
  transition-duration: 0.4s;
  width: 0;
}

.hide-show-element input:checked ~ .test1 {
  opacity: 1;
  height: 200px;
  width: 200px;
}
&#13;
<div class="hide-show-element">
  <input type="checkbox" id="toggle" />
  <label for="toggle"></label>
  <img class="test1" src="http://lorempixel.com/200/200" />
</div>
&#13;
&#13;
&#13;

答案 1 :(得分:2)

$('#id-of-your-div').fadeOut(); //fade out

$('#id-of-your-div').fadeIn(); //fade in div

查看文档以获取更多信息。

答案 2 :(得分:1)

如果你坚持使用jQuery,那也很容易实现。在单独的css类.show中显示时,定义要转换的样式。将transition-duration: 0.5s;添加到.test

然后

$(document).ready(function() {
  $('.showHideToggle').click(function() {
      var toggle= $(this);
      if ($(".test").hasClass("show")) {
          toggle.text("Hide");
          $(".test").removeClass("show");
      }
      else {
          toggle.text("Show");
          $(".test").addClass("show");
      }
  });
});

答案 3 :(得分:0)

假设您实际上在讨论文字css过渡,请打开和关闭一个类。如果你希望它淡出然后显示无,你需要使用动画长度的超时设置为最后显示无。无法通过过渡进行关键帧设置。

$(document).ready(function() {
  $('.usr').click(function() {
   $(".test").css('display','block').removeClass('hidden');
  });
  $(".hide").click(function() {
    $(".test").addClass('hidden');
    setTimeout(function(){
        $(".test").css('display','none')}, 500 //Animation Time
     )
  });
});

-

.test{
    opacity:1;
    transition:500ms cubic-bezier(0,0,0.58,1);
    -webkit-transition:500ms cubic-bezier(0,0,0.58,1);

}
.hidden{
    opacity:0;
}