Vue将页面导出为图片或者PDF


Posted in Javascript onAugust 17, 2020

本文实例为大家分享了Vue导出页面为PDF格式的具体代码,供大家参考,具体内容如下

导出为图片

1.将页面html转换成图片

npm install html2canvas --save

2.在需要导出的页面引入

import html2canvas from 'html2canvas';

在 methods 中添加方法

dataURLToBlob(dataurl) {//ie 图片转格式
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
     bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while (n--) {
     u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], {type: mime})
    },
  downloadResult(name) {
    let canvasID = document.body
    let a = document.createElement('a');
    html2canvas(canvasID).then(canvas => {
     let dom = document.body.appendChild(canvas);
     dom.style.display = "none";
     a.style.display = "none";
     document.body.removeChild(dom);
     let blob = this.dataURLToBlob(dom.toDataURL("image/png"));
     a.setAttribute("href", URL.createObjectURL(blob));
     a.setAttribute("download", name + ".png")
     document.body.appendChild(a);
     a.click();
     URL.revokeObjectURL(blob);
     document.body.removeChild(a);
    });
    },
   printOut(name) {
   // 个人观察只是截取可见范围以及以下的区域,所以先将滚动条置顶
    $(window).scrollTop(0); // jQuery 的方法
    document.body.scrollTop = 0; // IE的
    document.documentElement.scrollTop = 0; // 其他
    this.downloadResult(name)
  },

导出为PDF

1.将页面html转换成图片

npm install html2canvas --save

2.将图片生成pdf

npm install jspdf --save

3.在需要导出的页面引入

import html2canvas from 'html2canvas';
import JsPDF from 'jspdf'

在 methods 中添加方法

printOut(name) {
  let shareContent = document.body,//需要截图的包裹的(原生的)DOM 对象
   width = shareContent.clientWidth, //获取dom 宽度
   height = shareContent.clientHeight, //获取dom 高度
   canvas = document.createElement("canvas"), //创建一个canvas节点
   scale = 2; //定义任意放大倍数 支持小数
  canvas.width = width * scale; //定义canvas 宽度 * 缩放
  canvas.height = height * scale; //定义canvas高度 *缩放
  canvas.style.width = shareContent.clientWidth * scale + "px";
  canvas.style.height = shareContent.clientHeight * scale + "px";
  canvas.getContext("2d").scale(scale, scale); //获取context,设置scale
  let opts = {
   scale: scale, // 添加的scale 参数
   canvas: canvas, //自定义 canvas
   logging: false, //日志开关,便于查看html2canvas的内部执行流程
   width: width, //dom 原始宽度
   height: height,
   useCORS: true, // 【重要】开启跨域配置
  };

  html2Canvas(shareContent, opts).then(() => {
   var contentWidth = canvas.width;
   var contentHeight = canvas.height;
   //一页pdf显示html页面生成的canvas高度;
   var pageHeight = (contentWidth / 592.28) * 841.89;
   //未生成pdf的html页面高度
   var leftHeight = contentHeight;
   //页面偏移
   var position = 0;
   //a4纸的尺寸[595.28,841.89],html页面生成的canvas在pdf中图片的宽高
   var imgWidth = 595.28;
   var imgHeight = (592.28 / contentWidth) * contentHeight;
   var pageData = canvas.toDataURL("image/jpeg", 1.0);
   var 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(name + ".pdf"); // 这里是导出的文件名
  });
  },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js null,undefined,字符串小结
Aug 21 Javascript
利用JQuery和JS实现奇偶行背景颜色自定义效果
Nov 19 Javascript
jquery事件的ready()方法使用详解
Nov 11 Javascript
火狐和ie下获取javascript 获取event的方法(推荐)
Nov 26 Javascript
详解Vuex中mapState的具体用法
Sep 28 Javascript
js时间戳与日期格式之间转换详解
Dec 11 Javascript
解决VUEX兼容IE上的报错问题
Mar 01 Javascript
GOJS+VUE实现流程图效果
Dec 01 Javascript
vue中v-for通过动态绑定class实现触发效果
Dec 06 Javascript
Vue+ElementUI项目使用webpack输出MPA的方法
Aug 27 Javascript
Vue 嵌套路由使用总结(推荐)
Jan 13 Javascript
vue如何在项目中调用腾讯云的滑动验证码
Jul 15 Javascript
基于Bootstrap和JQuery实现动态打开和关闭tab页的实例代码
Jun 10 #jQuery
发布订阅模式在vue中的实际运用实例详解
Jun 09 #Javascript
为vue项目自动设置请求状态的配置方法
Jun 09 #Javascript
解决vue单页面应用中动态修改title问题
Jun 09 #Javascript
Vue动态修改网页标题的方法及遇到问题
Jun 09 #Javascript
详解Node.js异步处理的各种写法
Jun 09 #Javascript
在mpvue框架中使用Vant WeappUI组件库的注意事项【推进】
Jun 09 #Javascript
You might like
在Windows中安装Apache2和PHP4的权威指南
2006/10/09 PHP
php+curl 发送图片处理代码分享
2015/07/09 PHP
PHP+Mysql+jQuery文件下载次数统计实例讲解
2015/10/10 PHP
Laravel学习基础之migrate的使用教程
2017/10/11 PHP
php获取ajax的headers方法与内容实例
2017/12/27 PHP
TP5多入口设置实例讲解
2020/12/15 PHP
jquery 实现的全选和反选
2009/04/15 Javascript
三级下拉菜单的js实现代码
2011/05/23 Javascript
JavaScript高级程序设计 XML、Ajax 学习笔记
2011/09/10 Javascript
js控制的回到页面顶端goTop的代码实现
2013/03/20 Javascript
asp.net+js实现金额格式化
2015/02/27 Javascript
JavaScript中setTimeout的那些事儿
2016/11/14 Javascript
WebSocket实现简单客服聊天系统
2017/05/12 Javascript
JavaScript 判断对象中是否有某属性的常用方法
2018/06/14 Javascript
在 Angular6 中使用 HTTP 请求服务端数据的步骤详解
2018/08/06 Javascript
node中的密码安全(加密)
2018/09/17 Javascript
vue-cli中使用高德地图的方法示例
2019/03/28 Javascript
[00:27]DOTA2战队VP、Secret贺新春
2018/02/11 DOTA
Python实现的一个找零钱的小程序代码分享
2014/08/25 Python
Python时间模块datetime、time、calendar的使用方法
2016/01/13 Python
关于Django外键赋值问题详解
2017/08/13 Python
利用Python+Java调用Shell脚本时的死锁陷阱详解
2018/01/24 Python
python实现回旋矩阵方式(旋转矩阵)
2019/12/04 Python
python实现无边框进度条的实例代码
2020/12/30 Python
美国名牌太阳镜折扣网站:Eyedictive
2017/05/15 全球购物
Python里面search()和match()的区别
2016/09/21 面试题
高校生生产实习自我鉴定
2013/09/21 职场文书
道德模范先进事迹
2014/02/14 职场文书
学校政风行风整改方案
2014/10/25 职场文书
学校办公室主任岗位职责
2015/04/01 职场文书
小兵张嘎观后感
2015/06/03 职场文书
Python基础知识之变量的详解
2021/04/14 Python
HTML5简单实现添加背景音乐的几种方法
2021/05/12 HTML / CSS
浅谈pytorch中stack和cat的及to_tensor的坑
2021/05/20 Python
介绍一下28个JS常用数组方法
2022/05/06 Javascript
Nginx限流和黑名单配置
2022/05/20 Servers