57 lines
1.6 KiB
TypeScript
57 lines
1.6 KiB
TypeScript
import html2Canvas from 'html2canvas'
|
||
import jsPDF from 'jspdf'
|
||
|
||
export const exportToPDF = async (elementId: string, filename = 'document.pdf') => {
|
||
const element = document.getElementById(elementId)
|
||
if (!element) return
|
||
await html2Canvas(element, {
|
||
useCORS: true,
|
||
allowTaint: true,
|
||
logging: false,
|
||
scale: 2,
|
||
backgroundColor: '#fff',
|
||
}).then((canvas: any) => {
|
||
const pdf = new jsPDF('p', 'mm', 'a4')
|
||
const pageWidth = 190 // 保留边距后的有效宽度
|
||
const pageHeight = 277 // 保留边距后的有效高度 //A4大小,210mm x 297mm,四边各保留10mm的边距,显示区域190x277
|
||
const imgHeight = (pageHeight * canvas.width) / pageWidth
|
||
|
||
let renderedHeight = 0
|
||
while (renderedHeight < canvas.height) {
|
||
const pageCanvas = document.createElement('canvas')
|
||
pageCanvas.width = canvas.width
|
||
pageCanvas.height = Math.min(imgHeight, canvas.height - renderedHeight)
|
||
|
||
pageCanvas
|
||
.getContext('2d')!
|
||
.putImageData(
|
||
canvas
|
||
.getContext('2d')!
|
||
.getImageData(
|
||
0,
|
||
renderedHeight,
|
||
canvas.width,
|
||
Math.min(imgHeight, canvas.height - renderedHeight),
|
||
),
|
||
0,
|
||
0,
|
||
)
|
||
|
||
pdf.addImage(
|
||
pageCanvas.toDataURL('image/jpeg', 1.0),
|
||
'JPEG',
|
||
10,
|
||
10, // 左边距和上边距
|
||
pageWidth,
|
||
Math.min(pageHeight, (pageWidth * pageCanvas.height) / pageCanvas.width),
|
||
)
|
||
|
||
renderedHeight += imgHeight
|
||
if (renderedHeight < canvas.height) {
|
||
pdf.addPage()
|
||
}
|
||
}
|
||
pdf.save(filename)
|
||
})
|
||
}
|