“show”动画后jQuery选项卡回调

时间:2013-11-14 20:54:15

标签: jquery jquery-ui-tabs

我有一个jQuery UI选项卡的链接,需要显示选项卡,然后将其滚动到视图中。我的第一直觉是使用基本$('selector').tabs('option','active',1)来显示它,然后将回调绑定到tabsactivate事件,以将body元素的scrollTop设置为tabs容器的偏移量。应该简单吧?但是当我点击链接时,除非标签已经激活,否则页面不会滚动。

经过多次探索后,我发现了问题:选项卡上有一个150毫秒的淡入动画,并且在动画完成之前,tabs会激活火焰。因此,当我尝试获取其偏移量时,它为0,因为实际上尚未显示该选项卡。我很确定这是原因,因为如果我删除了显示/隐藏动画,它会按预期工作。

简而言之,我的问题是,是否可以将回调绑定到内置选项卡“show”动画,以便在动画完成之前不会触发?

如果没有,那么什么是一个好的解决方法?

编辑:问题可能不是我想的那样......发布以下代码。

代码(非常混乱且未经过优化)

<script>
$(function() {

$('.select-tab').click(function(e){
    var $target = $('#'+this.href.split("#")[1]),
        tabindex = $target.index('.ui-tabs-panel'),
        $tabParent = $target.parents('.ui-tabs-container');
    $tabParent.tabs('option','active',tabindex);
    e.preventDefault();
});

$(".scroll").each(function(){
    var $this = $(this),
        $target = $('#'+this.href.split("#")[1]),
        $tabParent = $target.parents('.ui-tabs-container'),
        clickHandler;

    function clickHandler(){
        $('html,body').animate({"scrollTop":$target.offset().top},500,'easeOutCubic');
    }

    if( $this.hasClass('select-tab') && $target.hasClass('ui-tabs-panel') ){
        $this.click(function(e){
            if( $target.index('.ui-tabs-panel') == $tabParent.tabs('option','active') ){
                clickHandler();
            } else{
                $(document).one('tabsactivate',$tabParent,function(e,ui){
                    clickHandler();
                });
            }
        });
    } else{
        $this.click(clickHandler);
    }
});

});
</script>

<a class="select-tab scroll" href="#ProductReviews">
    Read all 36 Reviews
</a>

<div class="ui-tabs-container ui-tabs ui-widget ui-widget-content ui-corner-all">
<ul id="product_tabs" class="ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all">
    <li class="ui-state-default ui-corner-top ui-tabs-active ui-state-active">
        <a href="#RelatedProducts">Related Products</a>
    </li>
    <li class="ui-state-default ui-corner-top">
        <a href="#ProductReviews">Product Reviews</a>
    </li>
    <li class="ui-state-default ui-corner-top">
        <a href="#OrderWithConfidence">Order With Confidence</a>
    </li> 
</ul>
<div id="RelatedProducts" class="ui-tabs-panel ui-widget-content ui-corner-bottom">
    <!-- Stuff Here -->
</div>
<div id="ProductReviews" class="ui-tabs-panel ui-widget-content ui-corner-bottom ui-helper-hidden">
    <!-- Stuff Here -->
</div>
<div id="OrderWithConfidence" class="ui-tabs-panel ui-widget-content ui-corner-bottom ui-helper-hidden">
    <!-- Stuff Here -->
</div>

1 个答案:

答案 0 :(得分:0)

jQuery UI选项卡有一个名为activate的方法,它会在动画完成后触发。

http://api.jqueryui.com/tabs/#event-activate

小提琴:http://jsfiddle.net/QT5Tm/