ScrollY: misaligned table headers with bootstrap

ScrollY: misaligned table headers with bootstrap

philipphilip Posts: 11Questions: 5Answers: 0
edited April 2017 in Scroller

With ScrollY enabled, our table headers are misaligned (too narrow). We have multiple tables but only the first has correct alignment while the others do not. Clicking a table header (to sort by column) causes the header for that table to resize correctly.

I've seen related issues but cannot resolve, and another user reported a similar issue (and includes a functional example that demonstrates the problem) although they use a bootstrap modal. Click their modal to see what I see:

https://datatables.net//forums/discussion/37108

I also use bootstrap and think it's related. Disabling ScrollY solves the alignment problem.

Related settings: "scrollY": '50vh', "scrollX": true, "scrollCollapse": true,

This question has an accepted answers - jump to answer

«1

Answers

  • philipphilip Posts: 11Questions: 5Answers: 0
    edited April 2017

    The solution / workaround used, and it mostly works:

    // Tabbed table headers were not sized correctly
    $(document).ready(function() {
        $('a[data-toggle="tab"]').on( 'shown.bs.tab', function (e) {
            $($.fn.dataTable.tables( true ) ).css('width', '100%');
            $($.fn.dataTable.tables( true ) ).DataTable().columns.adjust().draw();
        } ); 
    });
    

    Still a few issues to work out (e.g., misaligns when collapsing sidebar) but it's close.

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Yup - what you have looks like about spot on. If the table is initialised hidden then you need to use columns.adjust(). You should also have width="100%" (or style="width: 100%") on the table's HTML.

    Allan

  • philipphilip Posts: 11Questions: 5Answers: 0
    edited April 2017

    Thanks Allan, much appreciated. I threw together a test to demonstrate the current problem. This goes beyond the scope of data tables but perhaps you or someone here has a suggestion (or similar problem):

    http://www.codeply.com/go/XBL0Q5Q0Xb

    Click the hamburger to hide the main menu on the left and watch the table header. I used code from this example:

    https://datatables.net/examples/api/tabs_and_scrolling.html

    It includes a similar snippet:

        $('a[data-toggle="tab"]').on( 'shown.bs.tab', function (e) {
            $.fn.dataTable.tables( {visible: true, api: true} ).columns.adjust();
        } );
    

    Unfortunately the table headers don't adjust with the table body until after a user interaction takes place, such as ordering the table or clicking a tab.

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin
    Answer ✓

    The 'shown.bs.tab' event isn't going to be useful here since it isn't a Bootstrap tab that you are interacting with. Instead you need to know the event that is triggered when the animation of the side bar sliding away (or back in) is completed and then called columns.adjust() at that point.

    Allan

  • philipphilip Posts: 11Questions: 5Answers: 0

    Thanks Allan, it's now fixed although I understand it's a hack on my part. The AdminLTE sidebar part:

    $('body').on('expanded.pushMenu collapsed.pushMenu', function() {
        setTimeout(function(){
            $.fn.dataTable.tables( {visible: true, api: true} ).columns.adjust();
        }, 350);
    });
    

    It seems there isn't an event triggered when the slide animation completes but I'm still learning about event handling. But, at least adding an appropriate delay value makes it work.

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Perfect. Thanks for posting back!

    Events are awesome - as long as they exist and are documented :smile:

    Allan

  • eshkeleshkel Posts: 4Questions: 0Answers: 0

    hi, have similar problem with misaligned table header (header columns not corresponds to data columns). columns.adjust().draw() - not help in that case (don't see any changes - may be incorrect usage).

    link to sources attached, sorry for lot of code, and xxx,yyy used only to fill space.

    https://drive.google.com/file/d/1czuE-8_j5rYx1r9bZw7sxN-pQpAmF5oN/view?usp=sharing

    any help appreciated.

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Could you create a test case on http://live.datatables.net or JSFiddle please?

    Allan

  • eshkeleshkel Posts: 4Questions: 0Answers: 0

    Thank you for response - I'm new with jsfiddle, but seems it looks like I see it locally.
    Could you see it https://jsfiddle.net/eshkel/pmsy6wm9/4/?
    This looks good, but without vertical scroll https://jsfiddle.net/eshkel/t68q52rs/1/

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    It looks like it is this that is causing the issue:

    #itemsTableId thead th {
        ...
        padding:5px;
    }
    

    Removing that padding allows it to work as expected.

    I've made a few other changes as well:

    1. Include the DataTables Bootstrap integration
    2. Enable autoWidth.

    https://jsfiddle.net/pmsy6wm9/5/

    Regards,
    Allan

  • eshkeleshkel Posts: 4Questions: 0Answers: 0

    Thank you for advices, padding really make aligning better. But I noticed some issues on local version and played with JSFiddle. When I make JSFiddle version(#5) larger (on local version I try to use 1920x1080 resolution) the header looks inaccurate

    Also if change scrollY: "200px" aligning broken again https://jsfiddle.net/eshkel/pmsy6wm9/6/

    on my local version if I apply only changes related to padding - it looks much better, but if I applied all changes I see very wide columns (full screen on 1920x1080)

    the padding was introduced to make header more readable, is it any legal way to apply custom styles to header?

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Yes you can have custom padding, but you need to have it applied not based on the id, but rather by class name. When you have scrolling enabled, it will split the table into two or three parts, and since the id has to be unique, the id can only be on one of those parts.

    I'll try taking a look at the updated fiddle tomorrow - I'm travelling today, so its not ideal for debugging I'm afraid!

    Allan

  • eshkeleshkel Posts: 4Questions: 0Answers: 0

    thank you Allan for explanation related to ID and multiple tables (was not obvious for me) - added new class for table and moved styles to selectors with class instead of ID and it looks good on different resolution and sizes - except one point - I didn't enable autoWidth in local variant. If enabled - I see wide columns as I mentioned previously. Example with changes here https://jsfiddle.net/eshkel/pmsy6wm9/7/
    Could you point what should be checked to make autoWidth less greedy for space?

  • Sajadh92Sajadh92 Posts: 4Questions: 1Answers: 0
    edited April 2018

    Hi
    i have this issue ...
    when i add scroll Y to a dataTable the header of it not matched the body
    see the picture !!
    how can i fixed that ??

  • neanderthilneanderthil Posts: 7Questions: 1Answers: 0

    I recently had this issue with Jquery UI dialog. Only the first table would render improperly the second was fine... Very strange but after hours of struggling I just started setting random !important width: 100% overrides on the table elements. After setting it on the specific wrapper ID of that table (#table_wrapper) and then running columns.adjust().draw() after the dialog has fully opened, it seems to be working.

    So best I can tell it is a problem in the way the wrapper width is generated.

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Yes - you need to call columns.adjust() once the table is fully in place and visible. Otherwise height and width calculations aren't possible.

    Allan

  • vivek44uvivek44u Posts: 2Questions: 0Answers: 0

    HI I am facing same issue dataTable the header of it not matched the body while using scrollY: PPHeight . Any help will be highly appreciated, i have used many solutions but not working for me.

    **sharing code here **
    let tblHtmlOverlay = $('#tblHtmlOverlay').DataTable({
    dom: "Bfrtip",
    bSort: false,
    destroy: true,
    ServerMethod: "POST",
    lengthChange: true,
    responsive: false,
    deferRender: true,
    pageResize: false,
    fixedHeader: true,
    colReorder: true,
    rowReorder: true,
    data: A_Data, // We're assuming the Data matches the table construct
    paging: false,
    scrollY: PPHeight, /// This is resulting in an error. Appears to be a DataTables bug
    "scrollX": true, "scrollCollapse": true,
    columns: (this.hasHeader === true) ? AtlasPaste.tableHeaders.withheader : AtlasPaste.tableHeaders.thearray
    , "language": {
    "emptyTable": "Processing your data..."
    }
    });

  • kthorngrenkthorngren Posts: 21,002Questions: 26Answers: 4,889

    Looks like you are using FixedHeader. According to the compatibility matrix fixedHeader and scrolling featrues are not compatible. The FixedHeader Docs state this:

    Please note that FixedHeader is not currently compatible with tables that have the scrolling features of DataTables enabled (scrollX / scrollY).

    Kevin

  • vivek44uvivek44u Posts: 2Questions: 0Answers: 0

    @kthorngren yes using FixedHeader, so whats solution for this ?

  • mchmajmchmaj Posts: 1Questions: 0Answers: 0

    I'm also having the issue of header misalignment with scroll enabled for a table in modal. Triggering columns.adjust() on 'shown.bs.modal' did help in that the header gets aligned, but you can see the misaligned state and then if flickers and adjusts. Any advice on how to improve this behavior?

  • neonturkneonturk Posts: 1Questions: 0Answers: 0

    Hi,

    My solution;(I hope this issue is resolved in the new version.)

            var dt =$('#task_templates').DataTable(dt_opt);
    
            setTimeout(function () {
                 $($.fn.dataTable.tables( true ) ).DataTable().columns.adjust().draw();
            },200);
    
  • Saikat_banerjeeSaikat_banerjee Posts: 1Questions: 0Answers: 0

    Facing the same issue. tried all the solutions above and also the solutions from the related stack overflow thred, however no luck. Can anyone please help me.

    code:

    var table = $("#t-bleed").DataTable({
    "sScrollY": "200px",
    "bAutoWidth": false // Disable the auto width calculation
    });

    $(window).resize( function () {
    table.columns.adjust();
    } );

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    @Saikat_banerjee - Can you link to your page so we can take a look at this specific case please?

    Allan

  • jontxojontxo Posts: 12Questions: 2Answers: 0

    Hello

    I have a similar problem. This is the link of the jsfiddle: https://jsfiddle.net/jontxo/0tv6bzjk/7/

    Regards

  • colincolin Posts: 15,234Questions: 1Answers: 2,597

    @jontxo Your fiddle is giving a console error. Could you take a look, please, and once fixed, provide steps on how to reproduce the problem that you're seeing.

    Colin

  • jontxojontxo Posts: 12Questions: 2Answers: 0

    Thanks for answering. After solving the console issue it has been solved the issue with the columns.

    Regards

  • johndoojohndoo Posts: 18Questions: 5Answers: 1

    Happy new year to everyone !

    This issue still exists in datatables 1.10.22 with bootstrap4 and responsive options.

    The issue appears when adding "scrollY" parameter.
    Adding width=100% to table did not help.
    The column.adjust().draw() solves the issue but redraws all the datatable so it is too slow in my case.
    Is there any trick to just redraw the headers/footers by using the existing data columns widths (without refreshing all the table rows) ?

    Regards.

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Try removing the .draw() part of your call there.

    If that doesn’t help, please link to a test case showing the issue.

    Allan

  • johndoojohndoo Posts: 18Questions: 5Answers: 1

    Thanks a lot allan !

    Removing .draw() is much faster and works fine with the $(window).resize() event !

    But you have to do some "trick" to have it working: some kind of
    $('#some_parent_of_datatable table').DataTable().columns.adjust()

    There is still an issue with aldmintle side menu (when menu expands/collapses) but this is much much better now !

  • allanallan Posts: 62,873Questions: 1Answers: 10,345 Site admin

    Yes, if there is something that is changing the width of the table, then you'd need to call columns.adjust() for the DataTable to take that into account. It doesn't have an auto-detection of width change in the page (yet - it will in v2).

    Allan

This discussion has been closed.