当前位置: 首页 > news >正文

js 生成pdf 并上传文件

js 生成pdf 并上传文件

使用 JsPDF + html2Canvas 代码直接使用 注意注释

import JsPDF from 'jspdf'
import html2Canvas from 'html2canvas'
// 上传文件的方法
import { handleUploadImage } from '@/utils/uploadQuillEdit'downPDF() {//	 要打印元素的idconst cloneDom = document.getElementById('rentArea').cloneNode(true)document.getElementsByTagName('body')[0].appendChild(cloneDom)html2Canvas(cloneDom,{ allowTaint: true }).then((canvas) => {let contentWidth = canvas.widthlet contentHeight = canvas.heightlet pageHeight = contentWidth / 592.28 * 841.89let leftHeight = contentHeightlet position = 0let imgWidth = 595.28let imgHeight = 592.28 / contentWidth * contentHeightlet pageData = canvas.toDataURL('image/jpeg', 1.0)let PDF = new JsPDF('', 'pt', 'a4')if (leftHeight < pageHeight) {PDF.addImage(pageData, 'JPEG', 0, 0, imgWidth, imgHeight)} else {while (leftHeight > 0) {PDF.addImage(pageData, 'JPEG', 0, position, imgWidth, imgHeight)leftHeight -= pageHeightposition -= 841.89if (leftHeight > 0) {PDF.addPage()}}}// 将 PDF 转换为 Blob 对象const pdfBlob = PDF.output('blob')// file对象const pdfFile = new File([pdfBlob], `面积、期限及租金${new Date().getTime()}.pdf`, {type: 'application/pdf',lastModified: new Date().getTime()})//上传文件handleUploadImage(pdfFile).then(data => {console.log(data)})//这里是直接保存pdf// PDF.save(`${this.dataForm.customerNameShow}项目智能分仓方案书(${timeToTime(new Date(), false)}).pdf`)document.getElementsByTagName('body')[0].removeChild(cloneDom)})}

相关文章:

  • 查看MySql操作日志
  • chromedp 反反爬设计方案
  • AI大模型自然语言处理能力案例演示
  • 教育科技质检的三重挑战 质检LIMS系统在教育技术研发的应用
  • Spring开发系列教程(26)——异步处理
  • Kotlin 的 suspend 关键字
  • 什么是机器视觉3D无序堆叠抓取
  • 机器学习基础 - 分类模型之决策树
  • 【AI】SpringAI 第五弹:接入千帆大模型
  • FastText 模型文本分类实验:从零到一的实战探索
  • C# AppContext.BaseDirectory 应用程序的启动目录
  • django之数据的翻页和搜索功能
  • python 脚本引用django中的数据库model
  • L2-1、打造稳定可控的 AI 输出 —— Prompt 模板与格式控制
  • Python爬虫实战:获取xie程网敦煌酒店数据并分析,为51出行做参考
  • 火语言RPA--Ftp创建目录
  • 刷题之路:C++ 解题分享与技术总结
  • Mysql--基础知识点--79.1--双主架构如何避免回环复制
  • 设备预测性维护系统部署成本:技术架构与成本优化策略解析
  • JVM虚拟机-类加载器、双亲委派模型、类装载的执行过程
  • 调查丨当节气出现“时差”,陕西的果农们经历着什么?
  • 传媒湃︱《金陵晚报》副刊“雨花石”5月起改为免费刊登
  • 政治局会议:积极维护多边主义,反对单边霸凌行径
  • 证券时报:落实“非禁即入” ,让创新活力充分涌流
  • 印控克什米尔恐袭引爆印巴新一轮外交摩擦,地区安全风险骤增
  • 男子闲鱼卖手机卷入电诈案后成“网逃”续:警方已排除其作案嫌疑