vue 使用html2canvas + jsPDF 将html导出为pdf (延伸问题)

出现的问题:其中页面中的图片 导出之后不显示

一、最常见原因:图片跨域(90%都是这个)

❗现象

  • 页面上图片正常显示
  • 导出 PDF 图片消失

原因

html2canvas 在渲染 canvas 时,如果图片是 跨域资源,浏览器会阻止读取(安全策略),导致图片被"污染(tainted canvas)",最终导出为空。


解决方案

方案1:开启 useCORS

javascript 复制代码
html2canvas(element, {
    useCORS: true
})

前提条件:

  • 图片服务器必须支持跨域(有响应头)

Access-Control-Allow-Origin: *


方案2:图片加 crossOrigin

javascript 复制代码
<img src="https://xxx.com/image.png" crossorigin="anonymous" />

注意

如果服务器 没有配置 CORS,上面两个都没用!


方案3(推荐):转 Base64(最稳)

把图片转成 base64 再渲染:

javascript 复制代码
function getBase64Image(img) {
  const canvas = document.createElement("canvas");
  canvas.width = img.width;
  canvas.height = img.height;

  const ctx = canvas.getContext("2d");
  ctx.drawImage(img, 0, 0);

  return canvas.toDataURL("image/png");
}

👉 或后端直接返回 base64

二、图片未加载完成

现象

偶尔显示,偶尔不显示

解决

确保图片加载完再执行:

javascript 复制代码
await Promise.all(
  Array.from(document.images).map(img => {
    if (img.complete) return Promise.resolve();
    return new Promise(resolve => {
      img.onload = img.onerror = resolve;
    });
  })
);
相关推荐
时尚IT男7 分钟前
Python发票识别实战:从PDF中精准提取发票号与(小写)¥金额
开发语言·python·pdf
划水的code搬运工小李1 小时前
下载CSDN到PDF
开发语言·pdf·swift
2601_961194021 小时前
化学教资科三真题答案
linux·windows·ubuntu·pdf·centos·gnu
ZC跨境爬虫1 小时前
跟着 MDN 学CSS day_45:媒体查询入门指南——从语法到移动优先实践
前端·css·ui·html·tensorflow·媒体
Hoey2 小时前
虚拟 DOM 和 DIFF 算法
前端·vue.js
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_47:(移动优先实战——从手机到宽屏的响应式进化)
前端·css·html·tensorflow·媒体
小新1102 小时前
vue实战项目 计算器
前端·javascript·vue.js
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_46:(响应式实战——用媒体查询打造双列布局)
前端·css·ui·html·tensorflow·媒体
神仙别闹2 小时前
VUE框架 + Element UI + Node 模拟打印机的 Web 即时打印
前端·vue.js·ui
2601_961194022 小时前
2026初级会计实务教材电子版|章节讲义+习题PDF
python·考研·django·pdf·virtualenv·pygame