7
votes

So this is my HTML code where I'm trying to get whatever is outputted in the div abc to a downloadable pdf file.

<!-- Page Heading -->
<div class="row">
    <div class="col-lg-12">
        <h1 class="page-header">
            Reports
        </h1>
        <ol class="breadcrumb">
            <li>
                <i class="fa fa-dashboard"></i>  <a href="dashboard">Dashboard</a>
            </li>
            <li class="active">
                <i class="fa fa-edit"></i> Reports
            </li>

        </ol>
        <body>
          <div id="abc">
</div>
<div id="editor"></div>
<button id="cmd">Download Survey Report</button>
        <div id="abc">

        </div>
        </body>

        <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.3/jspdf.min.js"></script>
        <script>

                var doc = new jsPDF();
                var specialElementHandlers = {
                  '#editor': function (element, renderer) {
                return true;
            }
        };

        $('#cmd').click(function () {
            doc.fromHTML($('#abc').html(), 15, 15, {
                'width': 170,
                    'elementHandlers': specialElementHandlers
            });
            doc.save('SurveyReport.pdf');
        });
        </script>


        <script>
        firebase.auth().onAuthStateChanged(function(user){
          if(user){
            var userID = user.uid;
            RetrieveSurvey(userID,1,PrintSurvey(document.getElementById("abc")));
          }
        })
        </script>

    </div>
</div>

And I'm getting this error on the console:

"Uncaught ReferenceError: jsPDF is not defined"

I am not sure what I'm doing wrong here, I even added jsPDF in the script tag...

4
put your script inside <body> tag and try again.loelsonk
Why do you have <body></body> tags inside a <div>? Also ids are supposed to be unique, you cannot have 2 id="abc" tags.Rocket Hazmat

4 Answers

13
votes

Use this:

window.jsPDF = window.jspdf.jsPDF;
10
votes

First of all your HTML is invalid. Check W3S.

Put your link to jspdf inside <head> tag, you can do it even inside <body> tag.

Replace your jspdf script with latest one:

<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.4/jspdf.min.js"></script>
6
votes

as mentioned in https://github.com/matb/jsPDF use

<script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.2/jspdf.debug.js"></script>

add this script in head tag

-1
votes

use this:

window.jsPDF = require('jspdf');

instead of this:

import jsPDF from 'jspdf';