zoukankan      html  css  js  c++  java
  • h5页面导出为pdf两种方法(纯前端)

    <div class="row" id="pdfDom">
                        <van-cell-grounp>
                                <van-cell>
                                    业务咨询
                                </van-cell>
                                <van-cell>
                                    业务咨询
                                </van-cell>
                                <van-cell>
                                    业务咨询
                                </van-cell>
                                <van-cell>
                                    业务咨询
                                </van-cell>
                        </van-cell-grounp>
                    </div>                            
                <button @click="getPdf">文件下载</button>    
    <script src="js/html2canvas.js"></script>
    <script src="js/jspdf.js"></script>
    <script src="js/vue.min.js" ></script>        
    <script src="js/vant.min.js" ></script>
    var app=new Vue({
    
        el:"#app",
        data:function(){
        
        return{
                                
                 htmlTitle: "页面导出PDF文件名",
                 url:""
                           
            }
        
        },     
        methods:{
            
            getPdf:function(){
                        var title = this.htmlTitle
                          html2canvas(document.querySelector('#pdfDom'), {
                            allowTaint: true
                          }).then(function (canvas) {
                            var contentWidth = canvas.width
                            var contentHeight = canvas.height
                            var pageHeight = contentWidth / 592.28 * 841.89
                            var leftHeight = contentHeight
                            var position = 0
                            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(title + '.pdf');
                            console.log(PDF)                                                                                   
                          })                                
                    },
            
                          
      }
    })

    以上为pdf.js加html2canvas.js方法

    以下为pdfmake.js方法(这里写的例子只适合英文,中文暂时没研究)

    <button onclick="demo()">导出PDF</button>
    <script src="js/pdfmake.js" ></script>        
    <script src="js/vfs_fonts.js" ></script>
    function demo(){
    var cont = {
                    content: [
                        '中英文测试',
                        'Another paragraph, this time a little bit longer to make sure, this line will be divided into at least two lines'
                    ]
                };
     pdfMake.createPdf(cont).download();
    
    }
  • 相关阅读:
    Queue——C#浅谈
    C#设计模式(7)——适配器模式
    test
    python 技巧
    在centos 配置python django环境 总结
    pyqt5 做的小程序,可以用来UI做个小demo
    python sqlalthemy 总结
    数据清理,预处理 pandas dataframe 操作技巧 总结
    对区块链看法
    hadoop spark 总结
  • 原文地址:https://www.cnblogs.com/xiaobaibubai/p/12985952.html
Copyright © 2011-2022 走看看