Consistent grid headers with Flexigrid ?

前端 未结 12 1074
长发绾君心
长发绾君心 2021-02-03 10:05

So I\'m trying to use the flexigrid plugin. It looks like it\'s going to work great aside from the fact that it looks like you have to manually set the column widths. Otherwis

12条回答
  •  被撕碎了的回忆
    2021-02-03 10:52

    I ran into the same thing, finding out that the width of my divs containing the column headings and the table cells had the width = 0. So i had to wait a bit until the whole html-table was built, then i had to run the "format" method. Next thing is that i have the HTML table built in an invisible div at the beginning. So i had to omit the not(:hidden) selector within my code.

    Here we go:

        $.fn.flexAddData = function(data) { // function to add data to grid
           ...
        };
        // my own method to justify the column headers with the body
        $.fn.flexFormat = function() {
            return this.each(function() {
                var gridContainer = $('.flexigrid');
                var headers = gridContainer.find('.hDiv table tr:first th');
                var firstDataRow = gridContainer.find('.bDiv table tr:first td');
                var offSet = 10;
                // for each element in headers
                // compare width with firstDataRow elemts
                // the greater one sets the width of the lower one
                $.each(headers, function(i) {
                    var thWidth = $(this).find('div').outerWidth();
                    var tdWidth = $(firstDataRow[i]).find('div').outerWidth();
    
                    thWidth > tdWidth ? $(firstDataRow[i]).find('div').width(thWidth - offSet) : $(this).find('div').width(tdWidth - offSet);
    
                });
            });
        }; // end format
    

    The call for the method as follows:

        setTimeout(function() {
                $('.flexigrid').flexFormat();
            }
            , 10
        );
    

    Hope to have another solution for the problem ;-) Regards, Christoph

提交回复
热议问题