<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>Page Title</title> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" integrity="sha384-rwoIResjU2yc3z8GV/NPeZWAv56rSmLldC3R/AZzGRnGxQQKnKkoFVhFQhNUwEyJ" crossorigin="anonymous"> </head> <body class="container"> <input type="button" value="Print Pdf" onclick="generatePdf()" class="btn btn-default"> <div id="print-fields"> <div class="form-group row"> <label for="example-text-input" class="col-2 col-form-label">Text</label> <div class="col-10"> <input class="form-control" type="text" value="Artisanal kale" id="example-text-input"> </div> </div> <div class="form-group row"> <label for="example-search-input" class="col-2 col-form-label">Search</label> <div class="col-10"> <input class="form-control" type="search" value="How do I shoot web" id="example-search-input"> </div> </div> <div class="form-group row"> <label for="example-email-input" class="col-2 col-form-label">Email</label> <div class="col-10"> <input class="form-control" type="email" value="bootstrap@example.com" id="example-email-input"> </div> </div> <div class="form-group row"> <label for="example-url-input" class="col-2 col-form-label">URL</label> <div class="col-10"> <input class="form-control" type="url" value="https://getbootstrap.com" id="example-url-input"> </div> </div> <div class="form-group row"> <label for="example-tel-input" class="col-2 col-form-label">Telephone</label> <div class="col-10"> <input class="form-control" type="tel" value="1-(555)-555-5555" id="example-tel-input"> </div> </div> <div class="form-group row"> <label for="example-password-input" class="col-2 col-form-label">Password</label> <div class="col-10"> <input class="form-control" type="password" value="hunter2" id="example-password-input"> </div> </div> <div class="form-group row"> <label for="example-number-input" class="col-2 col-form-label">Number</label> <div class="col-10"> <input class="form-control" type="number" value="42" id="example-number-input"> </div> </div> <div class="form-group row"> <label for="example-datetime-local-input" class="col-2 col-form-label">Date and time</label> <div class="col-10"> <input class="form-control" type="datetime-local" value="2011-08-19T13:45:00" id="example-datetime-local-input"> </div> </div> <div class="form-group row"> <label for="example-date-input" class="col-2 col-form-label">Date</label> <div class="col-10"> <input class="form-control" type="date" value="2011-08-19" id="example-date-input"> </div> </div> <div class="form-group row"> <label for="example-month-input" class="col-2 col-form-label">Month</label> <div class="col-10"> <input class="form-control" type="month" value="2011-08" id="example-month-input"> </div> </div> <div class="form-group row"> <label for="example-week-input" class="col-2 col-form-label">Week</label> <div class="col-10"> <input class="form-control" type="week" value="2011-W33" id="example-week-input"> </div> </div> <div class="form-group row"> <label for="example-time-input" class="col-2 col-form-label">Time</label> <div class="col-10"> <input class="form-control" type="time" value="13:45:00" id="example-time-input"> </div> </div> </div> <script src="https://code.jquery.com/jquery-3.1.1.slim.min.js" integrity="sha384-A7FZj7v+d/sdmMqp/nOQwliLvUsJfDHW+k9Omg/a/EheAdgtzNs3hpfag6Ed950n" crossorigin="anonymous"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.4.0/js/tether.min.js" integrity="sha384-DztdAPBWPRXSA/3eYEEUWrWCy7G5KFbe8fFjk5JAIxUYHKkDx6Qin1DkWx51bBrb" crossorigin="anonymous"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js" integrity="sha384-vBWWzlZJ8ea9aCX4pEW3rVHjgjt7zpkNpZk+02D9phzyeVkE+jo0ieGizqPLForn" crossorigin="anonymous"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/es6-promise/4.1.1/es6-promise.auto.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.5/jspdf.min.js"></script> <script> function guid() { function S4() { return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1); } return (S4() + S4() + "-" + S4() + "-4" + S4().substr(0, 3) + "-" + S4() + "-" + S4() + S4() + S4()).toLowerCase(); } function generatePdf() { var doc = new jsPDF(); var element = document.getElementById('print-fields'); var yCoord = 30; var xCoord = 20; for (i = 1; i < 10; i++) { Array.from(element.children).forEach(_ => { var label = _.children[0].innerHTML; var value = _.children[1].children[0].value; doc.setFont('helvatica'); doc.setFontType('bold'); doc.text(xCoord, yCoord, label); doc.text(xCoord + 40, yCoord, ':'); doc.setFontType('normal'); doc.text(xCoord + 50, yCoord, value); yCoord += 10; if (yCoord > 280) { yCoord = 30; doc.addPage('a4', 1); } }); } var fileName = guid()+'.pdf'; doc.save(fileName); } </script> </body> </html>
Kaynak: https://github.com/MrRio/jsPDF