zoukankan      html  css  js  c++  java
  • angular jspaf

    import { Component, OnInit } from '@angular/core';
    import * as jsPDF from 'jspdf';
    import html2canvas from "html2canvas";
    
    @Component({
      selector: 'app-desigin',
      templateUrl: './desigin.component.html',
      styleUrls: ['./desigin.component.css']
    })
    export class DesiginComponent implements OnInit {
    
      constructor() { }
      ngOnInit() {
    
      }
      btn() {
    
        var target:any = document.getElementsByClassName("right-aside")[0];
        console.log(target)
        target.style.background = "#FFFFFF";
    
        console.log(html2canvas);
        console.log(jsPDF);
        html2canvas(target).then(function (canvas) {
    
              console.log(12)
              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');
    
              //有两个高度需要区分,一个是html页面的实际高度,和生成pdf的页面高度(841.89)
              //当内容未超过pdf一页显示的范围,无需分页
              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("content.pdf");
              // 转base64
              var datauri = pdf.output('dataurlstring')
              var base64 = datauri.substring(28);
              console.log(base64);
            }
        )
    
      }
    
    }
    

      

  • 相关阅读:
    芯片难题
    permutation
    小凸玩矩阵
    gender
    NOI2019序列非启发式做法
    莫比乌斯函数&莫比乌斯反演
    「雅礼day2」最大公约数gcd
    容斥原理&反演
    树上路径的交和并
    CF906D Power Tower
  • 原文地址:https://www.cnblogs.com/tiangeng/p/11651388.html
Copyright © 2011-2022 走看看