VUE 网页生成 PDF[通俗易懂]

VUE 网页生成 PDF[通俗易懂]保存当前网页为PDF格式到本地一、安装依赖1.npminstall–savehtml2canvas//作用是html转图片2.npminstalljspdf–save//再将图片转为pdf二、设置格式函数importhtml2Canvasfrom’html2canvas’importJsPDFfrom’jspdf’exportdef…

大家好,又见面了,我是你们的朋友全栈君。

保存当前网页为PDF格式到本地

一、安装依赖

1. npm install --save html2canvas  // 作用是html转图片
2. npm install jspdf --save  // 再将图片转为pdf

在这里插入图片描述

二、设置格式函数

import html2Canvas from 'html2canvas'
import JsPDF from 'jspdf'

export default{
  install (Vue, options) {
    Vue.prototype.getPdf = function (title) {
      html2Canvas(document.querySelector('#pdfDom'), {
        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 './htmlToPdf';

Vue.use(htmlToPdf);

在这里插入图片描述

四、运用

在这里插入图片描述

五、遇到问题

在这里插入图片描述
如图,在导出文件时,发现网络错误,可能是因为下载器不支持,首先换浏览器试一次,如果可以下载,则就是下载器不支持。

作者微信公众号“怪東瓜”,有问题私聊,我们共同探讨实用技术,练出最美身材。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/145983.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月16日 上午7:20
下一篇 2022年5月16日 上午7:40


相关推荐

  • YUI中js的继承示例

    YUI中js的继承示例无标题文档一个简单的例子。在这个例子中,可以看到,用var定义的私有变量,是不能被继承的。所有能被继承的,一定是通过this关键字,在内在地址中和这个对象的地址捆在一起的变量。因为复合对象传的不是值

    2022年7月4日
    24
  • 解决VS控制台窗口自动关闭的问题

    解决VS控制台窗口自动关闭的问题方法一 Ctrl F5 如果你的项目创建时选择的是 Win32 控制台应用程序 那么使用 Ctrl F5 运行程序就可以了 如果你选的是 空项目 你需要修改项目属性 才能让这个方法生效 方法二 设置断点在代码结束或返回前设置断点 方法三 system pause 在代码结束或返回前加一句话 system pause 需要头文件 includestdli h

    2026年3月17日
    1
  • 图像预处理方法总结

    图像预处理方法总结1 图像二值化 1 1 简单阈值或全局阈值 gray cv cvtColor image cv COLOR RGB2GRAY 把输入图像灰度化 ret binary cv threshold gray 0 255 cv THRESH BINARY cv THRESH TRIANGLE 简单阈值当然是最简单 选取一个全局阈值 然后就把整幅图像分成了非黑即白的二值图像

    2025年11月6日
    5
  • fizz buzz 翻译_thefizzbuzz中文翻译

    fizz buzz 翻译_thefizzbuzz中文翻译存档日期:2019年5月15日|首次发布:2010年10月26日GoogleBuzz允许用户将实时状态更新,新闻和内容发布到他们的Google帐户,并订阅其他人的类似更新。网络应用程序开发人员可以通过GoogleBuzzRESTAPI访问和搜索此内容。本文介绍了GoogleBuzzAPI,并在PHP应用程序上下文中对其进行了演示,并说明了如何在GoogleBuzz上…

    2022年10月15日
    4
  • CentOS7-命令-重启网卡命令(systemctl restart network)

    CentOS7-命令-重启网卡命令(systemctl restart network)重启网卡 root 用户 systemctlres 非 root 用户 sudosystemct

    2026年3月18日
    3
  • android 集成微信小程序支付

    android 集成微信小程序支付之前公司让集成微信小程序支付 过去得有一个月了 今天想了想还是记录一下吧 万一哪天有用到了呢在此之前咱们先引用别人文章里的官网文档要装作自己很认真的样子微信小程序开发步骤 https pay weixin com wiki doc api wxa wxa api php chapter 7 3 amp index 1 微信小程序 API https mp weixin

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号