PDF веб-страницы, созданной на основе JavaScript, отличается от веб-страницы

Я конвертирую свою веб-страницу в PDF с помощью html2pdf. Код, который конвертирует веб-страницу в html, как показано ниже

 $("#btnpdf").click(function() {
        var element = document.getElementById('target');
        html2pdf(element,{
      filename:     'MyPDF.pdf',
      image:        { type: 'jpeg', quality: 1 },

    });
    });

PDF генерируется, но данные в нем не ориентированы должным образом. Заголовки таблиц и виджеты под ним не совсем совпадают, как видно на веб-странице. Они несколько смещены от фактического положения на веб-странице.

HTML-код, который я использую, выглядит следующим образом

Мой HTML код

<div id="target">
<div class="gridster">
 <table border = "1" class=".table-responsive">
                    <tr>
                        <th colspan="4"  style="background-color:#05345c;">Zone 1</th>
                        <th colspan="4"  style="background-color:#05345c;">Zone  2</th>
                        <th colspan="4"  style="background-color:#05345c;">Zone  3</th>
                    </tr>
                    <tr>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 1</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 2</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 3</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 4</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 1</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 2</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 3</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 4</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 1</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 2</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 3</td>
                        <td width="400" align="center" style="background-color:#0085ca">Sub 4</td>
                    </tr>
                </table>
    <ul>
    </ul>

</div>
</div>
<div class="controls">
    <button class="js-seralize">Serialize</button>
</div>

<textarea id="log"></textarea>

                <button class="add-button btn btn-success mr-2">Add widget</button>

                <input type="button" class="btn btn-success mr-2" id="btnpdf" value="Download PDF"/>

Весь мой код JavaScript

Мой код JS

var gridster;


gridster = $(".gridster ul").gridster({
  widget_base_dimensions: [100, 100],
  widget_margins: [5, 5],
    serialize_params: function($w, wgd) {
            return {value:$w.find('textarea').val().trim() , col: wgd.col, row: wgd.row, size_x: wgd.size_x, size_y: wgd.size_y}
        },
  helper: 'clone',
  resize: {
    enabled: true
  }
}).data('gridster');

var json = [{
    "html": "Some big text ", //testing this failed
    "col": 1,
    "row": 1,
    "size_y": 2,
    "size_x": 2
}, {
    "html": "Brand1, Small text", 
    "col": 4,
    "row": 1,
    "size_y": 2,
    "size_x": 2
},

{
    "html": "Very big text",
    "col": 6,
    "row": 1,
    "size_y": 2,
    "size_x": 2
},


{
    "html": "Brand 5",
    "col": 1,
    "row": 3,
    "size_y": 1,
    "size_x": 1
}, {
    "html": "Brand 5",
    "col": 4,
    "row": 3,
    "size_y": 1,
    "size_x": 1
},

{
    "html": "Brand 5",
    "col": 6,
    "row": 3,
    "size_y": 1,
    "size_x": 1
}

];

for(var index=0;index<json.length;index++) {
    gridster.add_widget('<li class="new" ><button class="delete-widget-button" style="float: right;">-</button><textarea class="textareaclass">' +json[index].html+ '</textarea></li>',json[index].size_x,json[index].size_y,json[index].col,json[index].row);
}


    $('.js-seralize').on('click', function() {
        var s = gridster.serialize();
        $('.gridster ul li').each((idx, el) => { // grab the grid elements
            s[idx].html = $('textarea', el).html(); // add the html key/values
        });
        $('#log').val(JSON.stringify(s));
});

$(document).on("click", ".delete-widget-button", function() {
        var gridster = $(".gridster ul").gridster().data('gridster');
        gridster.remove_widget($(this).parent());
    });

     $(document).on( "click", ".add-button", function() {
        var gridster = $(".gridster ul").gridster().data('gridster');      
        //gridster.add_widget('<li><button class="delete-widget-button">-</button></li>', 1, 1);

        // get selected color value
        var color = $("#widget-color").val();

        // build the widget, including a class for the selected color value
        var $widget = $('<li>', {
          'style': 'background-color:' + color
        })
        .append($('<button>', {
          'class': 'delete-widget-button',
          'text':'-'
        }))
        .append($('<textarea>',{
        'class' : 'textareaclass'
        }));

        // add widget to the grid
        gridster.add_widget($widget, 1, 1);


    });

   $("#btnpdf").click(function() {
    var element = document.getElementById('target');
    html2pdf(element,{
  filename:     'MyPDF.pdf',
  image:        { type: 'jpeg', quality: 1 },

});
});

Ссылка Fiddle PDF, загруженный из Fiddle, содержит виджеты, которые не синхронизированы с Sub1, Sub2 и т. Д. Не так, как показывает фактическая веб-страница.

0 ответов

Другие вопросы по тегам