前端项目使用js将dom生成图片、PDF

在进行下方操作前,请你先安装 html2canvas 和 jspdf 包。

1、使用html2canvas将dom元素生成图片

javascript 复制代码
// 获取要转换的dom
const ele = document.getElementById("dom");
// 生成canvas对象
let canvas = await html2canvas(ele);

2、生成PDF对象,将生成的canvas对象转换成base64添加进PDF对象中

javascript 复制代码
// 新建JsPDF对象
const PDF = new jsPDF({
    orientation: 'p', //参数: l:横向  p:纵向
    unit: 'mm', //参数:测量单位("pt","mm", "cm", "m", "in" or "px")
    format: 'a4', //A4纸
})

// 将生成的canvas转换成base64添加进PDF对象中
PDF.addImage(canvas.toDataURL('image/jpeg', 1), 'JPEG', 10, 10);

// 使用PDF.save()方法进行保存
PDF.save(`${你的文件名}.pdf`)

3、进阶用法

1. canvas要生成的dom高度比较大,a4纸放不下怎么分页?

2. 如何构建pdf文件上传到服务器中?

4、完整代码

javascript 复制代码
// 新建JsPDF对象
const PDF = new jsPDF({
    orientation: 'p', //参数: l:横向  p:纵向
    unit: 'mm', //参数:测量单位("pt","mm", "cm", "m", "in" or "px")
    format: 'a4', //A4纸
})

// 将dom转换成canvas对象
const ele = document.getElementById("qkqqProbationDetail");
let canvas = await html2canvas(ele);
const ctx = canvas.getContext('2d')

//A4大小,210mm x 297mm,四边各保留10mm的边距,显示区域190x277
const a4w = 190
const a4h = 277
//按A4显示比例换算一页图像的像素高度
const imgHeight = Math.floor(a4h * canvas.width / a4w)
let renderedHeight = 0
while (renderedHeight < canvas.height) {
    let page = document.createElement("canvas");
    page.width = canvas.width;
    //可能内容不足一页
    page.height = Math.min(imgHeight, canvas.height - renderedHeight);

    //用getImageData剪裁指定区域,并画到前面创建的canvas对象中
    page.getContext('2d').putImageData(ctx.getImageData(0, renderedHeight, canvas.width, Math.min(imgHeight, canvas.height - renderedHeight)), 0, 0);

    // canvas转图片数据保留10mm边距
    PDF.addImage(page.toDataURL('image/jpeg', 1), 'JPEG', 10, 10, a4w, Math.min(a4h, a4w * page.height / page.width));

    renderedHeight += imgHeight;

    //判断是否分页,如果后面还有内容,添加一个空页
    if (renderedHeight < canvas.height) {
        PDF.addPage()
    }
}

// 简单版,不需要考虑分页
// PDF.addImage(canvas.toDataURL('image/jpeg', 1), 'JPEG', 10, 10)

// ** 
// dataurlstring 可以拿到base64来进行你的展示
// blob 可以拿到文件流进行上传操作
const pdf_base64 = PDF.output("dataurlstring");
const pdf_blob = PDF.output("blob");
// 使用File构造函数和blob数据创建一个新的File对象
const file = new File([pdf_blob], `${你的pdf}.pdf`, {
    type: "application/pdf",
});

// ** 不上传的话,直接调用保存,将pdf文件保存在你的电脑上
PDF.save(`${你的pdf}.pdf`)
相关推荐
IT_陈寒12 分钟前
Python开发者必看!10个高效数据处理技巧让你的Pandas代码提速300%
前端·人工智能·后端
只_只29 分钟前
npm install sqlite3时报错解决
前端·npm·node.js
FuckPatience33 分钟前
Vue ASP.Net Core WebApi 前后端传参
前端·javascript·vue.js
数字冰雹35 分钟前
图观 流渲染打包服务器
服务器·前端·github·数据可视化
JarvanMo36 分钟前
Flutter:我在网上看到了一个超炫的动画边框,于是我在 Flutter 里把它实现了出来
前端
returnfalse36 分钟前
前端性能优化-第三篇(JavaScript执行优化)
前端·性能优化
yuzhiboyouye41 分钟前
前端架构师,是架构什么
前端·架构
全马必破三44 分钟前
Buffer:Node.js 里处理二进制数据的 “小工具”
前端·node.js
web安全工具库1 小时前
Linux 高手进阶:Vim 核心模式与分屏操作详解
linux·运维·服务器·前端·数据库
一枚前端小能手1 小时前
🔥 SSR服务端渲染实战技巧 - 从零到一构建高性能全栈应用
前端·javascript