Bootstrap:如何使用默认的'淡入淡出','隐藏','入'类来淡化然后隐藏某些东西?

时间:2013-05-30 06:36:46

标签: jquery twitter-bootstrap show-hide

Bootstrap显然会使用'hide','fade'和'in'类进行转换。

我遇到的问题是使用'淡入'和'输入'会将不透明度从0更改为1.过渡效果非常完美,但内容仍占用页面空间,即使您看不到它。例如,如果它的容器有边框,边框前面会有一个很大的空白区域。

我想通过添加和删除'in'类来利用他们现有的CSS过渡,但我也想要隐藏任何淡出的元素,但只有在过渡结束后才能被隐藏。所以基本上,他们确实在模态中做了什么,但我不知道他们是怎么做的。

在下面的示例中,添加或删除隐藏意味着在淡入淡出效果发生之前,div会立即显示或消失。

JS fiddle here

示例HTML:

<div class="control-group">
    <label class="control-label">Choose one:</label>
    <div class="controls">
        <label class="radio inline">
            <input type="radio" name="color-radio" id="yellow-trigger" value="yellow" />Yellow Box</label>
        <label class="radio inline">
            <input type="radio" name="color-radio" id="red-trigger" value="red" />Red Box</label>
    </div>
</div>
<div id="yellow-box" class="hide fade">
    <p>I'm yellow</p>
</div>
<div id="red-box" class="hide fade">
    <p>I'm red</p>
</div>

示例JS:

$(document).ready(function () {
    $('#yellow-trigger').click(function () {
        $('#yellow-box').addClass('in').removeClass('hide');
        $('#red-box').addClass('hide').removeClass('in');
    });

    $('#red-trigger').click(function () {
        $('#red-box').addClass('in').removeClass('hide');
        $('#yellow-box').addClass('hide').removeClass('in');
    });
});

2 个答案:

答案 0 :(得分:15)

任何不使用jQuery作为fadeIn效果的原因?下面是一些使用jQuery实现淡入淡出的代码。

Fiddle here

删除了“淡入淡出”类

<div id="yellow-box" class="hide">
<p>I'm yellow</p> </div>

更新了jQuery for fade in

$(document).ready(function () {

  $('#yellow-trigger').click(function () {
      $('#red-box').hide();
      $('#yellow-box').fadeIn('slow');
  });

  $('#red-trigger').click(function () {
      $('#yellow-box').hide();
      $('#red-box').fadeIn('slow');     
  });

});

答案 1 :(得分:6)

这是非常古老的,但是如果有其他人到这里,答案是对合成事件bsTransitionEnd使用单次处理程序。

示例:

$(".alert").one('bsTransitionEnd',function() {
    $(this).addClass('hide');
});
window.setTimeout(function(){
    $(".alert").removeClass('in');
},1000);