jquery datatables scroll to top when pages clicked from bottom

后端 未结 7 493
余生分开走
余生分开走 2021-01-02 17:13

I am using a jQuery datatable with bottom pagination. When the pages are clicked from bottom , I want it to scroll it to top, so users do not have to manually do that for lo

相关标签:
7条回答
  • 2021-01-02 17:42

    Thank's from davidkonrad. But when I used his code, after I clicked on paginate button, scroll of page went to top and then after load data, scroll backed to bottom.

    I combined multiple posts in StackOverFlow and Datatables forum.

    I defined a global variable :

    var isScroll = false    
    

    When it's clicked on paginate button isScroll set to true:

    $(document).on('click', '.paginate_button:not(.disabled)', function () {
        isScroll = true;
    });
    

    And finally:

    $(document).ready(function () {
        $('#myDataTable').DataTable({
            ...
            "fnDrawCallback": function () {
                if (isScroll) {
                    $('html, body').animate({
                        scrollTop: $(".dataTables_wrapper").offset().top
                    }, 500);
                    isScroll = false;
                }
            },
            ...
        });
    });
    

    Thanks from @0110

    0 讨论(0)
  • 2021-01-02 17:45

    Since Datatables 1.10 there is this page event https://datatables.net/reference/event/page

    So one can use

    $('#example_table').on( 'page.dt', function () {
        $('html, body').animate({
            scrollTop: 0
        }, 300);
    } );
    

    Demo: https://jsfiddle.net/mcyhqrdx/

    0 讨论(0)
  • 2021-01-02 17:55

    None of the above answers worked for me. Here's my solution.

    $("#divContainingTheDataTable").click(function(event){
        if ($(event.target).hasClass("paginate_button")) {
            $('html, body').animate({
                 scrollTop: $("#divContainingTheDataTable").offset().top
            }, 200);
        }
    });
    

    I tried targetting .paginate_button but it never seemed to fire. My approach checks the div containing the datatable, if you click on the pagination buttons, the page scrolls up to the top of the container.

    0 讨论(0)
  • 2021-01-02 17:56

    Update. The original answer was targeting 1.9.x. In dataTables 1.10.x it is much easier :

    table.on('page.dt', function() {
      $('html, body').animate({
        scrollTop: $(".dataTables_wrapper").offset().top
      }, 'slow');
    });
    

    demo -> http://jsfiddle.net/wq853akd/

    Also, if you're using the bootstrap version of datatables, you may notice that when using the fix, the page actually scrolls back down after scrolling to the top. This is because it is focusing on the clicked button as per this datatables.net thread. You can fix this by simply focusing on the table header after the animate call, like so:

    table.on('page.dt', function() {
      $('html, body').animate({
        scrollTop: $(".dataTables_wrapper").offset().top
      }, 'slow');
    
      $('thead tr th:first-child').focus().blur();
    });
    

    Original Answer

    You should target .dataTables_wrapper and attach the event to .paginate_button instead. Here with a nice little animation :

    function paginateScroll() {
        $('html, body').animate({
           scrollTop: $(".dataTables_wrapper").offset().top
        }, 100);
        console.log('pagination button clicked'); //remove after test
        $(".paginate_button").unbind('click', paginateScroll);
        $(".paginate_button").bind('click', paginateScroll);
    }
    paginateScroll();
    

    see fiddle -> http://jsfiddle.net/EjbEJ/

    0 讨论(0)
  • 2021-01-02 17:57

    This worked out for me.

    $(document).ready(function() {
        var oldStart = 0;
        $('#example').dataTable({
            "bJQueryUI": true,
            "sPaginationType": "full_numbers",
            "fnDrawCallback": function (o) {
                if ( o._iDisplayStart != oldStart ) {
                    var targetOffset = $('#example').offset().top;
                    $('html,body').animate({scrollTop: targetOffset}, 500);
                    oldStart = o._iDisplayStart;
                }
            }
        });
    } );
    
    0 讨论(0)
  • I'm also using datatables and Allan's solution (found here) worked perfectly for me.

    $(document).ready(function() {
        var oldStart = 0;
        $('#example').dataTable({
            "bJQueryUI": true,
            "sPaginationType": "full_numbers",
            "fnDrawCallback": function (o) {
            if ( o._iDisplayStart != oldStart ) {
                var targetOffset = $('#example').offset().top;
                $('html,body').animate({scrollTop: targetOffset}, 500);
                oldStart = o._iDisplayStart;
            }
          }
        });
    } );
    
    0 讨论(0)
提交回复
热议问题