如何制作多重表头

12

我正在尝试制作一个具有两个标题合并的表格。目前,我用两个单独的表格和两个单独的标题制作了一个看起来还不错的表格,但是当表格宽度扩展时,第一个表头不会扩展。如何合并这两个表头或者可以制作一个具有两个表头的表格?请看图片(当前带有两个表头的表格)

当前的自动表格

这是我的代码:

function createPDF(){
             /** START PDF INSTANCE */
            //var doc = new jsPDF('p', 'pt');
            var doc = new jsPDF('l', 'pt');
            var row = 80;
            addPdfHeader(doc, row, vm.translate("REPORT.LEGALFORMS ")+" "+vm.activeCompanyYear);

            doc.setFillColor(33, 150, 243); 
            var columns = [ "               ",vm.activeCompanyYear,vm.activeCompanyYear-1,vm.activeCompanyYear-2];

            var rows = [];

            var description = "";
            for(var j=0; j<vm.reportData.length; j++){
                var obj = vm.reportData[j];


                description = obj.descriptionEng;

                if(description == "total"){
                    description = vm.translate("REPORT.REGISTRY.TOTAL");
                } 

                var singleRow = [description,
                                 obj.year3Total,
                                 obj.year3Local,
                                 obj.year3International,
                                 obj.year2Total,
                                 obj.year2Local,
                                 obj.year2International,  
                                 obj.year1Total,
                                 obj.year1Local,
                                 obj.year1International
                               ]
               rows.push(singleRow);
            }                       

            doc.autoTable(columns, [], {
                theme : 'grid',
                styles: {
                   halign: 'right'
                },
                headerStyles: {
                   fillColor: [33, 150, 243],
                   halign:'center',
                   lineWidth: 1,
                   lineColor: [221, 221, 221]

                },
                columnStyles:{
                     0: {columnWidth: 266}
                },
                margin : {
                  top : 100
                }
            });

            var columns2 = [ vm.translate("MENU.SETTINGS.LEGALFORM"), 
                             vm.translate("REPORT.REGISTRY.TOTAL"),
                             vm.translate("REPORT.REGISTRY.LOCAL"),
                             vm.translate("REPORT.REGISTRY.INTERNATIONAL"),
                             vm.translate("REPORT.REGISTRY.TOTAL"),
                             vm.translate("REPORT.REGISTRY.LOCAL"),
                             vm.translate("REPORT.REGISTRY.INTERNATIONAL"),
                             vm.translate("REPORT.REGISTRY.TOTAL"),
                             vm.translate("REPORT.REGISTRY.LOCAL"),
                             vm.translate("REPORT.REGISTRY.INTERNATIONAL")
                            ];

            doc.autoTable(columns2, rows, {
                theme : 'grid',
                styles: {
                   halign: 'right'
                },
                headerStyles: {
                   halign:'center',
                   lineWidth: 1,
                   lineColor: [221, 221, 221]
                },
                margin : {
                  top : 120
                },
                columnStyles:{
                     0: {halign:'left'}
                },
                createdCell: function(cell, data) {
                   if(data.row.raw[0] === vm.translate("REPORT.REGISTRY.TOTAL")) {
                      cell.styles.fontStyle = 'bold';
                      cell.styles.fillColor = [255,251,204];
                   }
                }

            });

            doc.save();
        };

正在为jspdf-autotable的3.0版本原生支持多个标题进行开发。在这个版本发布几天后会回来处理这个问题。 - Simon Bengtsson
@SimonBengtsson 有什么消息吗? - Luca Regazzi
addPdfHeader函数在哪里? - RamiReddy P
1个回答

10
类似这样(v3及以上版本):
let head = [
    [
        {content: 'People', colSpan: 3, styles: {halign: 'center', fillColor: [22, 160, 133]}}, 
        {content: 'Data', colSpan: 2, styles: {halign: 'center', fillColor: [22, 160, 133]}}
    ],
    ['ID', 'Name', 'Email', 'City', 'Sum'],
];

doc.autoTable({
    startY: 60,
    head: head,
    body: body,
    theme: 'grid'
});

Multiple headers with v3 of autotable


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接