036:vue导出页面生成pdf文件

news2024/10/2 22:23:31

在这里插入图片描述

第036个

查看专栏目录: VUE ------ element UI


专栏目标

在vue和element UI联合技术栈的操控下,本专栏提供行之有效的源代码示例和信息点介绍,做到灵活运用。

(1)提供vue2的一些基本操作:安装、引用,模板使用,computed,watch,生命周期(beforeCreate,created,beforeMount,mounted, beforeUpdate,updated, beforeDestroy,destroyed,activated,deactivated,errorCaptured,components,)、 $root , $parent , $children , $slots , $refs , props, $emit , eventbus ,provide / inject, Vue.observable, $listeners, $attrs, $nextTick , v-for, v-if, v-else,v-else-if,v-on,v-pre,v-cloak,v-once,v-model, v-html, v-text, keep-alive,slot-scope, filters, v-bind,.stop, .native, directives,mixin,render,国际化,Vue Router等

(2)提供element UI的经典操作:安装,引用,国际化,el-row,el-col,el-button,el-link,el-radio,el-checkbox ,el-input,el-select, el-cascader, el-input-number, el-switch,el-slider, el-time-picker, el-date-picker, el-upload, el-rate, el-color-picker, el-transfer, el-form, el-table, el-tree, el-pagination,el-badge,el-avatar,el-skeleton, el-empty, el-descriptions, el-result, el-statistic, el-alert, v-loading, $message, $alert, $prompt, $confirm , $notify, el-breadcrumb, el-page-header,el-tabs ,el-dropdown,el-steps,el-dialog, el-tooltip, el-popover, el-popconfirm, el-card, el-carousel, el-collapse, el-timeline, el-divider, el-calendar, el-image, el-backtop,v-infinite-scroll, el-drawer等

本文章目录

    • 专栏目标
    • 需求背景
    • 示例效果
    • 导出的结果
    • 示例源代码(共62行)
    • 安装依赖
    • 创建:html2pdf.js文件
    • main.js中全局引用

需求背景

在vue项目开发中,我们有的时候是要将页面中的内容导出为pdf格式的文件。在本示例中,我们就是如何演示将html转换为pdf文件的。

示例效果

在这里插入图片描述

导出的结果

在这里插入图片描述

示例源代码(共62行)

/*
* @Author: 大剑师兰特(xiaozhuanlan),还是大剑师兰特(CSDN)
* @此源代码版权归大剑师兰特所有,可供学习或商业项目中借鉴,未经授权,不得重复地发表到博客、论坛,问答,git等公共空间或网站中。
* @Email: 2909222303@qq.com
* @weixin: gis-dajianshi
* @First published in CSDN
* @First published time: 2022-09-20
*/
<template>
	<div class="container">
		<div class="top">
			<h3>vue导出页面生成pdf文件</h3>
			<div class="author">大剑师兰特, 还是大剑师兰特,gis-dajianshi</div>
		</div>
        <h4><el-button type="primary" @click="getPdf(htmlTitle)"> 导出为pdf文件</el-button> </h4>
		<div  id="zjcopyPDF">
			        <p>&nbsp;vue-router传递参数分为两大类</p>
					<div><strong>编程式的导航 router.push</strong></div>
					<div><strong>声明式的导航 &lt;router-link&gt;</strong></div>
					<div>&nbsp;</div>
					<h2>编程式导航</h2>
					<div>1)编程式导航传递参数有两种类型:字符串、对象。</div>
					<div><u><strong>字符串</strong></u></div>
					<div>字符串的方式是直接将路由地址以字符串的方式来跳转,这种方式很简单但是不能传递参数:</div>
					<div>this.$router.push(&quot;home&quot;);</div>
					<div><u><strong>对象</strong></u></div>
					<div>想要传递参数主要就是以对象的方式来写,分为两种方式:<strong>命名路由、查询参数,</strong>下面分别说明两种方式的用法和注意事项。</div>
							
		</div>
	</div>
</template>
<script>

	export default {
		data() {
			return {
              htmlTitle: 'PDF文件名' 
			}
		},
		methods: {

		},
	}
</script>
<style scoped>
	.container {
		width: 1000px;
		height: 580px;
		margin: 50px auto;
		border: 1px solid green;
		position: relative;
	}

	.top {
		margin: 0 auto 30px;
		padding: 10px 0;
		background: peru;
		color: #fff;
	}

	#zjcopyPDF{text-align: left; padding: 10px 50px;}
</style>



安装依赖

npm install --save html2canvas
npm install jspdf --save

创建:html2pdf.js文件

import html2Canvas from 'html2canvas' 
import JsPDF from 'jspdf' 
export default{ 
  install (Vue, options) { 
    Vue.prototype.getPdf = function () { 
      var title = this.htmlTitle 
      html2Canvas(document.querySelector('#zjcopyPDF'), { 
        allowTaint: true 
      }).then(function (canvas) { 
        let contentWidth = canvas.width 
        let contentHeight = canvas.height 
        let pageHeight = contentWidth / 592.28 * 841.89 
        let leftHeight = contentHeight 
        let position = 0 
        let imgWidth = 595.28 
        let imgHeight = 592.28 / contentWidth * contentHeight 
        let 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 -= pageHeight 
            position -= 841.89 
            if (leftHeight > 0) { 
              PDF.addPage() 
            } 
          } 
        } 
        PDF.save(title + '.pdf') 
      } 
      ) 
    } 
  } 
} 

main.js中全局引用

import htmlToPdf from ‘@/components/utils/htmlToPdf’
Vue.use(htmlToPdf)

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

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

相关文章

Git:利用Git进行多人协作的场景模拟

文章目录 场景一场景二解决一些后续问题 场景一 Git是一个多人协作下完成的操作&#xff0c;因此Git是需要进行一些多人协作的场景的&#xff0c;那么这里就使用Linux和Windows两个平台进行模拟实现两个用户进行的协作 首先把仓库克隆到本地&#xff0c;再加入两个用户的信息…

软件设计模式系列之十——组合模式

1 模式的定义 组合模式是一种结构型设计模式&#xff0c;用于将对象组合成树形结构以表示部分-整体层次结构。这个模式允许客户端以一致的方式处理单个对象和对象组合&#xff0c;因此它将单个对象和组合对象视为可互换的。 组合模式允许你将对象组合成树状结构来表示"部…

AI写作宝-为什么要使用写作宝

写作一直是一项需要创造力和思考的任务&#xff0c;人工智能&#xff08;AI&#xff09;正逐渐成为我们写作过程中的一位新伙伴。AI写作宝等在线AI写作工具正日益普及&#xff0c;为我们提供了更多的写作选择和可能性。 AI写作宝&#xff1a;什么是它们&#xff0c;以及它们能做…

国庆节都有哪些营销方案?

这里分享一些撰写国庆节营销方案的方法论&#xff0c;同时分享一些常见的国庆节营销方式。 1、确定活动时间&#xff1a; 一般来讲&#xff0c;国庆活动的最好时间是9月29日-10月7日&#xff0c;前期需要留有预热宣传的时间&#xff0c;告知用户活动的主题以及福利政策 2、确…

媒体发稿的步骤与技巧:打造品牌曝光与声誉

媒体发稿是企业、组织和个人获取曝光和传播信息的重要途径之一。通过媒体发稿&#xff0c;可以向目标受众传递重要的信息、推广产品或服务、塑造品牌形象等。然而&#xff0c;对于许多人来说&#xff0c;媒体发稿的流程和步骤可能会感到复杂和困惑。本文将为您介绍媒体发稿的基…

怒刷LeetCode的第7天(Java版)

目录 第一题 题目来源 题目内容 解决方法 方法一&#xff1a;二分贪心 方法二&#xff1a;二分DP 第二题 题目来源 题目内容 解决方法 方法一&#xff1a;双指针 方法二&#xff1a;暴力搜索 方法三&#xff1a;排序 第三题 题目来源 题目内容 解决方法 方法一…

【算法】单调栈

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

“高级Java注解的简介及应用“

目录 引言1. Java注解简介1.1 什么是注解1.2 注解的作用1.3 常见的Java注解 2. 自定义注解案例3. AOP自定义注解的应用3.1 AOP简介3.2 AOP自定义注解 总结 引言 在Java开发中&#xff0c;注解是一种非常重要的语言特性&#xff0c;它们可以为代码提供额外的信息和元数据。本文…

MFC 绘图

效果图&#xff1a;三张bmp图 字 竖线 组成 在OnPaint()函数中 CPaintDC dc(this);CRect rect;GetClientRect(&rect); //获取客户区矩形CDC dcBmp; //定义并创建一个内存设备环境dcBmp.CreateCompatibleDC(&dc); //创建兼容性DCCBitmap …

如何把利用paddlepaddle导出的json文件转化为yolo或者voc文件

目录 1. 修改源码&#xff0c;让模型能够生成出对于单个图像的标注。 2. 把数据转为yolo格式 3.把yolo格式转化为xml格式 这两天想偷懒&#xff0c;想让模型先在数据上标一遍&#xff0c;然后我再做修正&#xff0c;主要是图个省事。由于我们主要是利用paddle,模型也是基于p…

python+django学习资料在线分享系统vue

本站是一个B/S模式系统&#xff0c;采用vue框架作为开发技术&#xff0c;MYSQL数据库设计开发&#xff0c;充分保证系统的稳定性。系统具有界面清晰、操作简单&#xff0c;功能齐全的特点&#xff0c;使得校园资料分享平台管理工作系统化、规范化。技术栈 后端&#xff1a;pyth…

同城信息服务源码 本地生活服务小程序源码

同城信息服务源码 本地生活服务小程序源码 功能介绍&#xff1a; 基本设置&#xff1a;网站参数、安全设置、分站管理、支付设置、操作日志、地区设置、公交地铁、国际区号、清理缓存、模板风格、模块管理、域名管理、底部菜单、消息通知、登录设置 其他设置&#xff1a;关键…

Linux内核源码分析 (B.7)深入理解 slab cache 内存分配全链路实现

Linux内核源码分析 (B.7)深入理解 slab cache 内存分配全链路实现 文章目录 Linux内核源码分析 (B.7)深入理解 slab cache 内存分配全链路实现1\. slab cache 如何分配内存2\. slab cache 的快速分配路径3\. slab cache 的慢速分配路径3.1 从本地 cpu 缓存 partial 列表中分配3…

小程序多种姿势更换文章

概述 简单的文章切换demo&#xff0c;通过倒计时、摇一摇、双击进行文章切换 详细 直接看效果图吧&#xff01;比较简单&#xff0c;主要是练习一下... 小程序不带双击事件&#xff0c;可以记录第一次单击事件和第二次单机事件进行双击操作。 1、摇一摇是通过调用官方的 …

将多个元素循环起来构成迭代器itertools.cycle()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 将多个元素循环起来 构成迭代器 itertools.cycle() 选择题 以下说法错误的是? import itertools a[1,2,3] print("【显示】a:");print(a) bitertools.cycle(a) print("【执行】…

MVC设计思想理解和ASP.NET MVC理解

三层模式 三层模式包括:UI层,业务逻辑层,数据访问层,模型层 MVC设计思想和ASP.NET MVC理解 MVC设计思想: MVC的思想就是把我们的程序分为三个核心的模块,这三个模块的详细介绍如下: 模型(Model) :负责封装与引用程序的业务逻辑相关的数据以及对数据的处理方法。模型层有对…

Redis 列表操作实战(全)

目录 LINDEX 获取指定下标元素 LSET 指定下标添加元素 LPUSH 将元素插入列表头 LPUSHX RPUSH 将元素插入列表尾 RPUSHX LINSERT 将元素插入列表某位置之前 LLEN 列表长度 LPOP 取列表头元素 RPOP 取列表尾元素 BLPOP 阻塞式取列表头元素 BRPOP 阻塞式取列表尾元素…

精品Python医院挂号信息管理系统

《[含文档PPT源码等]精品基于Python实现的医院挂号信息管理系统》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程等 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;python 使用框架&#xff1a;Django 前端技术&#xff1a;JavaScript、…

智能指针解读(2)

前面一篇文章&#xff0c;我讲解了智能指针的原理&#xff0c;并实现了一个简单的智能指针。为了加深对智能指针的理解&#xff0c;在这篇文章中&#xff0c;我把C中的几个智能指针讲解下&#xff1a;auto_ptr, unique_ptr, shared_ptr, weak_ptr。 1、auto_ptr 前面的文章我…

在服务器上创建git仓库

1、在服务器上创建git仓库 选择一个创建文件夹的地方&#xff0c;这个地方不会将源码存放在这里&#xff0c;只用于版本控制 # 创建一个专门放置git的文件夹&#xff0c;也可以叫其它名 mkdir git && cd git # 创建自己项目的文件夹&#xff0c;文件夹后面要带 .git…