javascript - jsPDF 损坏的 PDF?

标签 javascript html pdf jspdf

我正在尝试使用 jsPDF 使用 JavaScript 创建 PDF 文件。我有一个小测试页。基本上我有一个下载 PDF 按钮,它从一个跨度中获取 base64 图像并将其用于 imgData。然后,我尝试将图像数据 addImage 保存到 pdf 中。一切似乎都正常,它生成 PDF 并提示下载。但是,当我尝试使用 xpdf 或 Foxit 阅读器查看 PDF 时,我被告知 PDF 已损坏。 我是否错误地创建了这个 PDF?我的网页很长,所以我把它放在了 Pastebin 上.

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />   
<script type="text/javascript" src="js/jquery/jquery-1.7.1.min.js"></script>
<script type="text/javascript" src="js/jquery/jquery-ui-1.8.17.custom.min.js"></script>
<script type="text/javascript" src="../jspdf.js"></script>
<script type="text/javascript" src="../libs/FileSaver.js/FileSaver.js"></script>
<script type="text/javascript" src="../libs/BlobBuilder.js/BlobBuilder.js"></script>
<script type="text/javascript" src="../jspdf.plugin.addimage.js"></script>
<script type="text/javascript" src="../jspdf.plugin.standard_fonts_metrics.js"></script>
<script type="text/javascript" src="../jspdf.plugin.split_text_to_size.js"></script>
<script type="text/javascript" src="../jspdf.plugin.from_html.js"></script>
<script type="text/javascript" src="js/basic.js"></script>
<title>Sup!</title>
<script>
function changeCan() {
  var c = document.getElementById("myCanvas");
  var ctx = c.getContext("2d");
  ctx.fillStyle="#FF0000";
  ctx.fillRect(0,0,128,128);
}
function changeCan3() {
  var c = document.getElementById("myCanvas");
  var ctx = c.getContext("2d");
  ctx.fillStyle="#FFFFFF";
  ctx.fillRect(0,0,128,128);
  var image = new Image();
  image.src = document.getElementById("3span").innerHTML;
  ctx.drawImage(image,0,0);
}
function changeCan4() {
  var imgData = document.getElementById("3span").innerHTML;
  window.alert(imgData.length);
  var doc = new jsPDF();
  doc.addImage(imgData, 'JPEG', 15, 40, 128, 128);
  doc.save('Test.pdf');
}
</script>
</head>
<body>
  Yo!<hr>
  <canvas id="myCanvas" width="128" height="128"></canvas><hr>
  <button type="button" onClick="changeCan()">Change Me To Red!</button>
  <button type="button" onClick="changeCan3()">Change Me To Span!</button>
  <button type="button" onClick="changeCan4()">Download Me!</button>
  <hr>
  <span id="3span" style="display:none;">B64 DATA HERE</span>
</body>
</html>

最佳答案

我遇到了类似的问题,这就是解决方法。我用了Blob.js , canvas-toBlob , FileSaver .我还注意到最新的 BlobBuilder.min.js 没有正常工作,所以我改用了 BlobBuilder.js。

var content = canvas.toDataURL('image/jpeg');
var doc = new jsPDF('landscape');
doc.addImage(content, 'JPEG', 0, 0);

var data = doc.output();
var buffer = new ArrayBuffer(data.length);
var array = new Uint8Array(buffer);

for (var i = 0; i < data.length; i++) {
    array[i] = data.charCodeAt(i);
}

var blob = new Blob(
    [array],
    {type: 'application/pdf', encoding: 'raw'}
);

saveAs(blob, filename);

关于javascript - jsPDF 损坏的 PDF?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14431894/

相关文章:

html - session 管理方法在移动原生应用程序、混合应用程序和 Web 应用程序中有何不同?

swift - 使用 SWIFT 解析 PDF

pdf - 无法从 pdf 中删除注释

ios - 如何在 xcode 中将 UIImage 转换为 PDF 文件?

javascript - mysql 查询错误 "Unhandled promise rejection"

javascript - 修改字符串中的 for 循环

javascript - jQuery 等到异步 ajax 调用完成

javascript - 使用 JavaScript 对对象进行排序和数组

Python:引用表格中的行

html - 缺少 IMG src 导致多个未知服务器请求