vue使用pdf 导出当前页面,(jspdf, html2canvas )

news2025/1/16 9:10:57

需要安装两个插件

npm install `html2canvas` jspdf
yarn add html2canvas jspdf
<div class="app-container" id="pdfPage">
	我是内容
</div>

<el-button size="mini" @click="onExportPdf">导出数据</el-button>
onexportPDF() {
      html2canvas(document.querySelector("#pdfPage"), {
        scale: 2, // 设置画布缩放比例
        allowTaint: true, // 允许加载跨域图片
        useCORS: true, // 使用跨域资源共享加载图片
        // scaleFonts: true, // 缩放字体
      }).then((canvas) => {
        var pdf = new jsPDF('p', 'mm', 'a4') // A4纸,纵向

        var ctx = canvas.getContext('2d')

        var a4w = 180;
        var a4h = 280 // A4大小,210mm x 297mm,四边各保留20mm的边距,显示区域170x257

        var imgHeight = Math.floor(a4h * canvas.width / a4w) // 按A4显示比例换算一页图像的像素高度

        var renderedHeight = 0

        while (renderedHeight < canvas.height) {
            var 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)
            pdf.addImage(page.toDataURL('image/jpeg', 1.0), 'JPEG', 10, 10, a4w, Math.min(a4h, a4w * page.height / page.width)) // 添加图像到页面,保留10mm边距
            renderedHeight += imgHeight

            if (renderedHeight < canvas.height) {
                pdf.addPage()
            } // 如果后面还有内容,添加一个空页
        }
        pdf.save('能力模型图' + ".pdf");
      }

这个是导出后的
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1104578.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SAP MM物料移动取总账科目逻辑,debug 标准bapi BAPI_GOODSMVT_CREATE

debug 标准bapi BAPI_GOODSMVT_CREATE perform mb_create_goods_movement function MB_CREATE_GOODS_MOVEMENT function MB_CREATE_MATERIAL_DOCUMENT perform buchen_aufbereiten perform F-SEGMENTE_GENERIEREN perform f-segmente_erstellen perform f-segmente_erzeugen p…

C语言参悟-函数

C语言参悟-函数 一、概述二、函数1. 函数的构成2. 函数参数3. 函数名4. 函数返回值5. 函数的工作1. 程序栈2、栈帧的组织 三、函数递归四、函数指针 一、概述 首先&#xff0c;什么是函数&#xff1f;函数&#xff08;function&#xff09;是完成特定任务的独立程序代码单元。…

五金仓库管理员的工作内容

近几年来&#xff0c;很多企业会发现&#xff0c;经营增长的压力越来越大&#xff0c;主要原因包括外部局势的巨变&#xff0c;市场捉摸不定&#xff1b;企业之间竞争越来越剧烈&#xff0c;企业的利润空间不断被压缩&#xff1b;员工越来越个性化、多元化&#xff0c;管理困难…

文档外发控制与安全:实现高效协作与数据安全的关键

随着企业数据量的不断增加&#xff0c;文档外发成为了一个不可避免的需求。然而&#xff0c;很多企业在文档外发过程中存在着很多问题&#xff0c;如数据泄露、信息误用等。因此&#xff0c;如何保证文档外发的安全性和高效性成为了企业亟待解决的问题。飞驰云联Ftrans的文件收…

软件工程与计算(十四)详细设计中面向对象方法下的模块化

一.面向对象中的模块 1.类 模块化是消除软件复杂度的一个重要方法&#xff0c;每个代码片段相互独立&#xff0c;这样能够提高可维护性。在面向对象方法中&#xff0c;代码片段最重要的类&#xff0c;整个类的所有代码联合起来构成独立的代码片段。 模块化希望代码片段由两部…

以烟草行业为例,聊聊如何基于 PLC + OPC + TDengine,快速搭建工业生产监测系统

在烟草工业场景里&#xff0c;多数设备的自动控制都是通过 PLC 可编程逻辑控制器来实现的&#xff0c;PLC 再将采集的数据汇聚至 OPC 服务器。传统的 PI System、实时数据库、组态软件等与 OPC 相连&#xff0c;提供分析、可视化、报警等功能&#xff0c;这类系统存在一些问题&…

Tortoise SVN 察看本地缓存密码

1、打开设置&#xff08;Settings&#xff09; 2、查看保存的数据 3、打开鉴权数据 4、查看密码 CTRLSHIFT双击表格&#xff0c;就会出现一列密码列 &#xff08;我的是Mac PD虚拟Win11&#xff0c;CTRLSHIFTOPTION双击表格&#xff09; 原文见这里&#xff1a; Recover SVN …

解密新一代商业智能软件百度GBI,看看它有多牛!

10月17日&#xff0c;2023百度世界大会开幕了&#xff0c;大家都关注了吗&#xff1f;本次大会上发布了关于商业智能&#xff08;Business Intelligence&#xff09;的工具百度GBI。那么首先给大家列出2022年全球商业智能(BI)和分析平台市场的相关数据&#xff1a; 总规模&…

HTML 常用标签及练习

常用标签 <head>中的标签 概述 head中的内容不显示到页面上 标签说明<title>定义网页的标题<meta>定义网页的基本信息&#xff08;供搜索引擎&#xff09;<style>定义CSS样式<link>链接外部CSS文件或脚本文件<script>定义脚本语言<…

Docker逃逸---CVE-2019-5736浅析

一、产生原因 Docker执行命令时&#xff0c;先向镜像管理的containerd发送gRPC请求&#xff0c;containerd收到请求后&#xff0c;再发送给具体的容器管理containerd-shim&#xff0c;shim根据OCI协议将命令发送给runc执行&#xff0c;所以实际上执行命令的是runc 漏洞大概意思…

C++ Eigen 矩阵运算

文章目录 1 Eigen的安装与CMakeLists.txt的编写1.1、Eigen的安装1.2、Eigen的CMakeLists.txt编写1.3、版本查看 2、Eigen的头文件3、Eigen的基础3.1 Eigen初始化3.1.1 一些常用的初始化方法 3.2 矩阵大小3.3 Eigen矩阵类3.4 Eigen矩阵的创建4 Eigen的Array类4.1 Array的初始化4…

JavaScript爬虫程序实现自动化爬取tiktok数据教程

以下是一个使用 request-promise 和 JavaScript 的爬虫程序&#xff0c;用于爬取tiktok的内容。此程序使用了 https://www.duoip.cn/get_proxy 这段代码。 // 引入 request-promise 库 const rp require(request-promise);// 定义 get\_proxy 函数 function get_proxy() {retu…

千兆光模块存在哪些局限性

千兆光模块是目前使用最广泛的光模块之一&#xff0c;可以实现1Gbps的传输速度。随着科技的进步和应用场景的多样性&#xff0c;千兆光模块也因其固有的局限性而面临越来越多的挑战。以下是千兆光模块的局限性和如何克服这些局限性的讨论&#xff1a; 千兆光模块可以实现最大…

钻井平台升降装置锁紧液压系统比例阀放大器

钻井平台升降装置锁紧液压系统为钻井平台桩腿的锁紧装置提供动力&#xff0c;通过液压马达驱动垂直布置的上下螺杆传动装置的伸缩&#xff0c;使锁紧齿条和桩腿上的弦管齿条啮合和分离&#xff0c;实现平台的锁紧、负载转移、均载和解锁。

05 依赖倒置原则

官方定义&#xff1a; 依赖倒置原则&#xff08;Dependence Inversion Principle&#xff0c;DIP&#xff09;是指在设计代码架构 时&#xff0c;高层模块不应该依赖于底层模块&#xff0c;二者都应该依赖于抽象。抽象不应该依 赖于细节&#xff0c;细节应该依赖于抽象。 通俗…

Linux系统添加硬件设备流程

Linux系统添加硬件设备的流程 添加硬盘设备的操作&#xff1a; 一、在虚拟机中模拟添加入一块新的硬盘存储设备 &#xff08;步骤见《Linux这么学》P191&#xff09; 二、依次进行分区、格式化、挂载操作 1.分区 &#xff08;1&#xff09;新建、修改及删除磁盘的分区表信息 #…

PAM从入门到精通(五)

接前一篇文章&#xff1a;PAM从入门到精通&#xff08;四&#xff09; 本文参考&#xff1a; 《The Linux-PAM Application Developers Guide》 先再来重温一下PAM系统架构&#xff1a; 更加形象的形式&#xff1a; 五、主要函数详解 3. pam_set_item 概述&#xff1a; 设置…

可追溯性在MES管理系统解决方案中的重要性

在当今制造业中&#xff0c;“可追溯性”已经变得至关重要。它能够在产品出现问题时迅速定位问题源头&#xff0c;并持续优化生产流程&#xff0c;确保产品质量得到提升和保持稳定。 可追溯性不仅涉及追踪产品来源&#xff0c;还是一种保障数据真实性的手段。与数据安全技术相…

OTP语音芯片和TTS语音芯片的差异性

OTP&#xff08;One-Time Programmable&#xff09;语音芯片和TTS&#xff08;Text-to-Speech&#xff09;语音芯片是两种不同类型的声音处理芯片。OTP主要用于播放预录声音片段&#xff0c;而TTS则根据文本实时生成语音。OTP的灵活性较弱&#xff0c;适用于固定声音输出&#…

组件自定义事件 和 解绑事件

组件自定义事件 和 解绑事件 组件自定义事件 功能&#xff1a;父组件绑定数据&#xff0c;子组件触发事件。&#xff08;父绑子触发&#xff09; 实现步骤&#xff08;前三步在父组件实现&#xff0c;第四步在子组件实现&#xff09;&#xff1a; 第一步&#xff1a;提供事件…