使用html2canvas和jsPDF导出pdf文件、把pdf文件传给后端

需求:前端获取dom节点生成pdf文件,然后将文件传递给后端。

1、引入插件

javascript 复制代码
import html2canvas from "html2canvas";
import jsPDF from 'jspdf'

2、前端导出pdf

javascript 复制代码
// 获取HTML元素
const element = document.getElementById("aswerDom");
const options = {
  dpi: 192,  //dpi属性的值为192,表示图像的分辨率
  scale: 2, //scale属性的值为2,表示图像的缩放比例。
  backgroundColor: "#ffffff",  //backgroundColor属性的值为"#ffffff",表示图像的背景颜色。
  useCORS: true,// 【重要】开启跨域配置
  allowTaint: true,// 允许跨域图片
};
// 将元素转换为canvas对象
html2canvas(element, options).then((canvas) => {
  let contentWidth = canvas.width;   //获取Canvas(上面元素id 'aswerDom')对象的宽度
  let contentHeight = canvas.height; //获取Canvas(上面元素id 'aswerDom')对象的高度
  // 创建jsPDF对象
  const pdf = new jsPDF('1', 'pt', [contentWidth, contentHeight]); //创建一个新的PDF对象,参数包括页面格式('1'表示A4纸张)、单位('pt')和页面尺寸([contentWidth, contentHeight])
  let pageData = canvas.toDataURL('image/jpeg', 1.0);  //将Canvas对象转换为JPEG格式的数据,并将其存储在pageData变量中。1.0表示图片质量
  console.log(pageData)
  pdf.addImage(pageData, 'JPEG', 0, 0, contentWidth, contentHeight);  //将JPEG格式的图片添加到PDF文件中,图片的左上角坐标为(0, 0),宽度为contentWidth,高度为contentHeight
  pdf.save('问卷统计分析报告' + new Date().getTime() +'.pdf');
});

效果如图:

但是需求是不在本地导出,而是把导出的内容传递给后端,所以需要删掉 pdf.save('问卷统计分析报告' + new Date().getTime() +'.pdf');

javascript 复制代码
......
pdf.addImage(pageData, 'JPEG', 0, 0, contentWidth, contentHeight);  //将JPEG格式的图片添加到PDF文件中,图片的左上角坐标为(0, 0),宽度为contentWidth,高度为contentHeight
//pdf.save('问卷统计分析报告' + new Date().getTime() +'.pdf');

const pdfBlob = pdf.output('blob');
const formData = new FormData();
formData.append('file', pdfBlob, '问卷统计分析报告' + new Date().getTime() +'.pdf');
formData.append('projectid', props.projectId);
formData.append('projectRlid',selectedQuestionnaires.value[0])
formData.append('projectRlFileType','questionnaire')

// 上传文件
ProjectOperationEvaluationApi.uploadProjectFile(formData).then(res => {
    btnLoading.value = false
    if (res.code == '00000') {
      message.success('问卷关联成功')
      emit('confirm', selectedQuestionnaires.value)
    } else {
        message.error('文件上传失败')
    }
}).catch((error) => {
    btnLoading.value = false
    console.error('文件上传失败:', error)
    message.error('文件上传失败')
})
});

在流程结束时,后端统一导出所有文件:

至此,需求完成!

相关推荐
百事牛科技5 天前
保护文档安全:PDF限制功能详解与实操
windows·pdf
开开心心就好5 天前
安卓开源应用,超时提醒紧急人护独居安全
windows·决策树·计算机视觉·pdf·计算机外设·excel·动态规划
Felicia-侧听6 天前
如何统一PDF页面宽度?统一pdf宽度的2种方法
pdf·pdf宽度统一
开开心心_Every6 天前
音频格式互转工具,支持Mp3ApeWavFlac互转
linux·运维·服务器·typescript·edge·pdf·asp.net
2501_930707786 天前
如何使用C#代码从 PDF 中提取表格并另存为Excel文件
pdf·excel
悟乙己6 天前
实施手册:如何自己构建财务PDF文件内容抽取引擎
pdf
xin_yao_xin6 天前
PDF 转 图片(python)
python·pdf
汤姆百宝箱7 天前
2026新版教材电子课本1-9年级新教材PDF(完整电子版下载)
pdf·小学课本·初中课本·电子教材·电子课本·2026新教材·2026新课本
开开心心就好7 天前
内存清理软件灵活设置,自动阈值快捷键清
运维·服务器·windows·pdf·harmonyos·risc-v·1024程序员节
海兰7 天前
【接上篇】多格式文档支持扩展方案(PDF_Word_Excel)
pdf·word·excel