2

我添加了一些 JQuery 选项卡,每次单击其中一个选项卡时,链接的 ID 都会附加到 url 并跳转到 url,这真的很烦人。我已经寻找了一些修复程序,例如设置超时和停止回发,但似乎没有任何效果,有人有什么想法吗?

<script type="text/javascript">

      $(document).ready(function () {        

          $('.moo').click(function (evt) {
            // stops from submitting the form
            evt.preventDefault();
            return false;
        });


        $("#tabs").tabs();

        setTimeout(function () {
            if (location.hash) {
                window.scrollTo(0, 0);
            }
        }, 1);

    });

</script>




<div id="tabs">
    <ul>
        <li><a href="#tabs-1" class="moo" onclick="return false;" >Nunc tincidunt</a></li>
        <li><a href="#tabs-2" class="moo" onclick="return false;" >Proin dolor</a></li>
    </ul>

    <div id="tabs-1">
        <uc1:PrizeDrawMiniListControl ID="PrizeDrawMiniListControl1" runat="server" />
    </div>

    <div id="tabs-2">
        <uc2:MostViewedControl ID="MostViewedControl1" runat="server" />
    </div>
</div>

编辑:

链接没有发回,它只是滚动

4

3 回答 3

5

http://jsfiddle.net/3au7K/现在工作正常。

将您的javascript函数更改为此

$(document).ready(function () {        

      $('.moo').click(function (evt) {
        // stops from submitting the form
        evt.preventDefault();
        return false;
    });


    $("#tabs").tabs();

    // This will work for dynamically added tabs as well

    $("#tabs ul li").delegate('a', 'click', function(e){
         e.preventDefault();
         return false;
    });
});

这个小技巧可以解决问题。它没有什么害处,因为 JQuery 选项卡在初始化后不需要 href 属性。

于 2012-09-17T09:17:53.573 回答
1

从锚标记中删除onclick=return false;并尝试这样:

$('a[href^="tabs-"]').on('click', function(e) {
  e.preventDefault();
});
于 2012-09-17T09:04:19.163 回答
0

这将防止任何锚从 jquery 选项卡跳转:) (将滚动位置移回原始点击)。

$('div.ui-tabs ul li a').click(function(e) {
  e.preventDefault();
  scroll_position = $(window).scrollTop();
  $('html, body').animate({
    scrollTop: scroll_position
  }, 0);
});
于 2015-12-10T19:40:48.920 回答