将 div 保存为 PDF 时未定义 jsPDF

bas*_*que 5 javascript jquery pdf-generation referenceerror jspdf

我正在尝试使用 jsPDF 保存具有特定 id 的 div 元素,但获取Uncaught ReferenceError: jsPDF is not defined. 尝试了许多不同的方法来解决这个问题,包括 stackoverflow 上的所有可用解决方案,但都没有奏效。

下面是 div 元素的样子(它是一个根据用户选择自动填充的表格,我删除了大部分选项以减少此示例的行数)。下面是一个快速片段,可以让您了解正在发生的事情。它仍然说 jsPDF 没有定义:

$('#savePDF').click(function() {
  var pdf = new jsPDF('p', 'pt', 'letter');
        source = $('#yourSummary');
        specialElementHandlers = {
            '#bypassme': function (element, renderer) {
                return true
            }
        };
        margins = {
            top: 80,
            bottom: 60,
            left: 40,
            width: 522
        };
        pdf.fromHTML(
            source,
            margins.left,
            margins.top, {
                'width': margins.width,
                'elementHandlers': specialElementHandlers
            },

            function (dispose) {
                pdf.save('your-summary.pdf');
            }, margins
        );
});
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://unpkg.com/jspdf@latest/dist/jspdf.umd.min.js"></script>
<div id="yourSummary" class="modal-body">
  <table id="yourExterior" class="table table-hover">
  <h5>Exterior</h5>
    <tbody>
     <tr>
      <th scope="row">Body colour</th>
      <td id="sumBC"></td>
     </tr>
    </tbody>
  </table>
</div>
<button class="btn-primary" id="savePDF">Save configuration as PDF</button>
Run Code Online (Sandbox Code Playgroud)

但是一旦我在浏览器中按下按钮,我就会出现以下错误:

Uncaught ReferenceError: jsPDF is not defined
at HTMLButtonElement.<anonymous> (main.js:34)
at HTMLButtonElement.dispatch (jquery-3.5.1.slim.min.js:2)
at HTMLButtonElement.v.handle (jquery-3.5.1.slim.min.js:2)
Run Code Online (Sandbox Code Playgroud)

我做错了什么以及如何解决这个问题?

Tat*_*yan 10

使用以前的版本
<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.min.js"></script>

2.0.0 版本非常不同。
例如,您将使用 jspdf.jsPDF 而不是方法“jsPDF”,但您会看到新的错误。

  • 仅供参考:[jsPDF 2.0 版](https://github.com/MrRio/jsPDF/releases)。 (2认同)