Bootstrap显然会使用'hide','fade'和'in'类进行转换。
我遇到的问题是使用'淡入'和'输入'会将不透明度从0更改为1.过渡效果非常完美,但内容仍占用页面空间,即使您看不到它。例如,如果它的容器有边框,边框前面会有一个很大的空白区域。
我想通过添加和删除'in'类来利用他们现有的CSS过渡,但我也想要隐藏任何淡出的元素,但只有在过渡结束后才能被隐藏。所以基本上,他们确实在模态中做了什么,但我不知道他们是怎么做的。
在下面的示例中,添加或删除隐藏意味着在淡入淡出效果发生之前,div会立即显示或消失。
示例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');
});
});
答案 0 :(得分:15)
任何不使用jQuery作为fadeIn效果的原因?下面是一些使用jQuery实现淡入淡出的代码。
删除了“淡入淡出”类
<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);