全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Vue网页html转换PDF(最低兼容ie10)的思路详解

HTML转PDF:

1.页面底层实现——Vue:最低兼容ie10  

2.实现思路:

  1> 使用html2canvas.js将网页转换为图片

  2> 使用jsPdf.debug.js将canvas生成的图片转换为pdf文件

具体实现:

  要这样实现首先要引入两个插件:

    html2canvas.js

    jsPdf.debug.js

注:

  因为ie10在canvas截图时候会出现部分样式丢失的情况,所以在代码中有部分修改了页面的样式

  所以建议在做截图的时候,将页面代码复制一份到隐藏域,在隐藏域里面做修改,这样就不会修改页面原有样式了

  如果大家有更好的方法,欢迎提议

下面上代码:

<script type="text/ecmascript-6">
import co from 'co'
import html2Canvas from '../html2canvas'
import JsPDF from '../jsPdf.debug'
export default {
 title: '用户信息',
 data () {
  return {}
 },
 methods: {
   // 核心代码
  printOut () {
    // 获取需要打印的区域,以div为单位,此处使用的是vue的选择器
   let pdfDom = document.querySelector('#pdf-wrap')
    // 因为在ie10下,会出现input样式丢失的情况,所以在此处清楚input的标签的边框
   let arrnode = pdfDom.querySelectorAll('input')
   for (var i = 0; i < arrnode.length; i++) {
    arrnode[i].style.border = 'hidden'
   }
    // 设置背景色
   pdfDom.style.background = '#FFFFFF'
   let _this = this
   html2Canvas(pdfDom, {
    allowTaint: true, taintTest: false,
    onrendered: function (canvas) {
      // 开始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
      // 此处图片格式可以是PNG,也可是JPEG,注意:需要考虑Browser支持的图片格式
     let pageData = canvas.toDataURL('image/PNG', 1)
     pdfDom.style.display = 'none'
      // 开始将图片转换为PDF
      // 设置纸张大小,方向
     let PDF = new JsPDF('', 'pt', 'a4')
     if (leftHeight < pageHeight) {
      PDF.addImage(pageData, 'PNG', 0, 0, imgWidth, imgHeight)
     } else {
      while (leftHeight > 0) {
       PDF.addImage(pageData, 'PNG', 0, position, imgWidth, imgHeight)
       leftHeight -= pageHeight
       position -= 841.89
       if (leftHeight > 0) {
        PDF.addPage()
       }
      }
     }
      // 保存PDF
     PDF.save(_this.userInfo.card_id + '-' + _this.userInfo.user_name + '.pdf')
    }
   })
   html2Canvas()
  }
 },
 ready () {
 }
}
</script>

总结

以上所述是小编给大家介绍的Vue网页html转换PDF(最低兼容ie10)的思路详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# vue网页html转换PDF  # vue导出html、word和pdf的实现代码  # vue将html页面生成高清晰pdf文件的方法  # 转换为  # 小编  # 的是  # 在此  # 中有  # 给大家  # 准备工作  # 所述  # 给我留言  # 感谢大家  # 背景色  # 疑问请  # 有任何  # 选择器  # html2Canvas  # JsPDF  # export  # default  # ecmascript  # text 


相关文章: 制作充值网站的软件,做人力招聘为什么要自己交端口钱?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何快速搭建二级域名独立网站?  如何选择适配移动端的WAP自助建站平台?  家具网站制作软件,家具厂怎么跑业务?  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  建站主机是什么?如何选择适合的建站主机?  nginx修改上传文件大小限制的方法  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  建站主机服务器选型指南与性能优化方案解析  制作网站的模板软件,网站怎么建设?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  常州自助建站费用包含哪些项目?  如何快速搭建高效WAP手机网站吸引移动用户?  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  教学论文网站制作软件有哪些,写论文用什么软件 ?  建站之星安装失败:服务器环境不兼容?  开源网站制作软件,开源网站什么意思?  制作电商网页,电商供应链怎么做?  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  如何通过服务器快速搭建网站?完整步骤解析  如何在万网主机上快速搭建网站?  兔展官网 在线制作,怎样制作微信请帖?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  C++时间戳转换成日期时间的步骤和示例代码  简单实现Android文件上传  如何用wdcp快速搭建高效网站?  建站之星安装步骤有哪些常见问题?  建站中国官网:模板定制+SEO优化+建站流程一站式指南  如何在建站之星网店版论坛获取技术支持?  如何挑选优质建站一级代理提升网站排名?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  如何通过NAT技术实现内网高效建站?  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  建站之星与建站宝盒如何选择最佳方案?  无锡营销型网站制作公司,无锡网选车牌流程?  ,在苏州找工作,上哪个网站比较好?  建站为何优先选择香港服务器?  内网网站制作软件,内网的网站如何发布到外网?  在线教育网站制作平台,山西立德教育官网?  微信h5制作网站有哪些,免费微信H5页面制作工具?  打鱼网站制作软件,波克捕鱼官方号怎么注册?  如何在橙子建站中快速调整背景颜色?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  建站之星导航菜单设置与功能模块配置全攻略  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?  实现虚拟支付需哪些建站技术支撑?  重庆网站制作公司哪家好,重庆中考招生办官方网站?  建站之星如何实现五合一智能建站与营销推广? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。