使用 JSPdf 生成将整个 html 页面导出为 pdf

问题描述 投票:0回答:2

我已经将这些js文件添加到我的aspx页面中。但我仍然无法获取表格数据的 pdf 文件。生成的pdf是空白的。我需要将所有表格数据放入生成的 pdf 中。有谁知道该怎么做吗?

<script src="../Script/jspdf.js"></script>
<script src="../Script/FileSaver.js"></script>
<script src="../Script/Blob.js"></script>
<script src="../Script/BlobBuilder.js"></script>
<script src="../Script/deflate.js"></script>
<script src="../Script/adler32cs.js"></script>
<script src="../Script/jspdf.plugin.addhtml.js"></script>
<script src="../Script/jspdf.plugin.from_html.js"></script>
<script src="../Script/jspdf.plugin.split_text_to_size.js"></script>
<script src="../Script/jspdf.plugin.standard_fonts_metrics.js"></script>
<script src="../Script/base64.js"></script>
<script src="../Script/sprintf.js"></script>

// 这是我的 aspx 表或 div 内容:

<div id="divReport" style="display: none">
    <input type="button" id="btnSavePdf" value="Save as Pdf" />
    <table id="example">
        <tr id="trProject">
            <td><span>Project :</span></td>
            <td><span id="spanProject" runat="server"></span></td>
        </tr>
        <tr>
            <td><span>Total Number of Employee :</span></td>
            <td>
                <asp:Label ID="spanTotalEmp" runat="server" EnableViewState="false" ClientIDMode="Static"></asp:Label>
            </td>
        </tr>
        <tr>
            <td><span>Total Number of Hours :</span></td>
            <td>
                <asp:Label ID="spanTotalHours" runat="server" name="_name2" EnableViewState="false" ClientIDMode="Static"></asp:Label>
            </td>
        </tr>
    </table>
</div>

// 下面是我的 Javascript 按钮 onclick 代码:

$('#btnSavePdf').click(function () {
                
            var doc = new jsPDF('p', 'in', 'letter');
            var source = $('#divReport').html();
            var specialElementHandlers = {
                '#bypassme': function (element, renderer) {
                    return true;
                }
            };
    
            doc.fromHTML(
                source, // HTML string or DOM elem ref.
                0.5,    // x coord
                0.5,    // y coord
                {
                    'width': 7.5, // max width of content on PDF
                    'elementHandlers': specialElementHandlers
                });
    
            doc.output('dataurl');
javascript jquery ajax pdf jspdf
2个回答
2
投票

我假设您只想渲染表格而不是整个页面。您可以使用 HTML 表导出 jQuery 插件 来完成此操作。这就是您的 HTML 的样子:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>

    <!-- jQuery 2.0.2 -->
    <script type="application/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.2/jquery.min.js"></script>

    <script type="application/javascript" src="tableExport.js"></script>
    <script type="application/javascript" src="jquery.base64.js"></script>
    <script type="application/javascript" src="jspdf/libs/sprintf.js"></script>
    <script type="application/javascript" src="jspdf/jspdf.js"></script>
    <script type="application/javascript" src="jspdf/libs/base64.js"></script>
</head>

<body>
<table id="example">
   <!-- rows here -->
</table>    
<a href="#" onclick ="$('#example').tableExport({type:'pdf',escape:'false'});">As PDF</a>
</body>
</html>

1
投票

style="display:none"
会阻止它渲染,因此你会得到一个空白页面。

也就是说,我认为您使用的是相当旧的模板,因为

sprintf.js
base64.js
大约三年前被删除了。您只需包含
dist
文件夹中可用的文件之一即可。

https://github.com/MrRio/jsPDF/tree/master/dist

这里有一个使用最新版本的 HTML 表示例:http://jsfiddle.net/dGLmr/7/

© www.soinside.com 2019 - 2024. All rights reserved.