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;
    });
  })
);
相关推荐
酉鬼女又兒2 小时前
零基础快速入门前端CSS Transform 与动画核心知识点及蓝桥杯 Web 应用开发考点解析(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·css·职场和发展·蓝桥杯·html
徐小夕3 小时前
花了一周时间,我们开源了一款PDF编辑SDK,支持在线批注+脱敏
前端·vue.js·github
前端Hardy3 小时前
NW.js v0.109.1 最新稳定版发布:被遗忘的桌面开发神器?启动快 3 倍,内存省 70%!
前端·javascript·vue.js
其实秋天的枫3 小时前
2026年新大纲普通话考试真题题库50套【PDF电子版】
经验分享·pdf
踩着两条虫3 小时前
AI驱动的Vue3应用开发平台 深入探究(十四):扩展与定制之插件系统开发指南
vue.js·人工智能·低代码·重构·架构
PieroPc4 小时前
用tkinter 做一个通过 扫描仪硬件 扫描纸质文档的软件 支持pdf
python·pdf·扫描
Jay叶湘伦4 小时前
【极简】用 Vue 写一个 ChatGPT 前端应用,支持连续对话、Markdown 渲染与本地记忆
前端·vue.js·chatgpt
pengles5 小时前
基于RuoYi-Vue-Plus项目实现移动端项目
java·vue.js·uni-app
sensen_kiss6 小时前
CAN302 电子商务技术 Pt.2 深入了解HTML和CSS
前端·css·学习·html
Traced back6 小时前
[特殊字符] Vue3 常用指令大全
前端·javascript·vue.js