导出pdf

function  exportPDF(container, fileName) {

        var pdfDom = $(container);

        var w = pdfDom.width(); // 获得该容器的宽

        var h = pdfDom.height(); // 获得该容器的高

        var offsetTop = pdfDom.offset().top; // 获得该容器到文档顶部的距离

        var offsetLeft = pdfDom.offset().left; // 获得该容器到文档最左的距离

        var canvas = document.createElement('canvas');

        var abs = 0;

        var win_i = $(window).width(); // 获得当前可视窗口的宽度(不包含滚动条)

        var win_o = window.innerWidth; // 获得当前窗口的宽度(包含滚动条)

        if (win_o > win_i) {

            abs = (win_o - win_i) / 2; // 获得滚动条长度的一半

        }

        canvas.width = w * 4; // 将画布宽&&高放大4倍

        canvas.height = h * 4;

        var context = canvas.getContext('2d');

        context.scale(4, 4);

        context.translate(-offsetLeft - abs, -offsetTop);

        // 这里默认横向没有滚动条的情况,因为offset.left(),有无滚动条的时候存在差值,因此

        // translate的时候,要把这个差值去掉

        html2canvas(pdfDom, {

            allowTaint: true,

            taintTest: true,

            canvas: canvas,

            dpi: 172, // 导出pdf清晰度

            onrendered: function(canvas) {

                // 开始canvas截图

                // 开始准备工作

                var contentWidth = canvas.width;

                var contentHeight = canvas.height;

                // 一页pdf显示html页面生成的canvas高度;

                var pageHeight = contentWidth / 595.28 * 841.89;

                // 未生成pdf的html页面高度

                var leftHeight = contentHeight;

                // pdf页面偏移

                var position = 0;

                // a4纸的尺寸[595.28,841.89],html页面生成的canvas在pdf中图片的宽高

                var imgWidth = 555.28;

                var imgHeight = 555.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();

                        }

                    }

                }

                let date = new Date()

                let year = date.getFullYear() + ''

                let month = date.getMonth() + 1 >= 10 ? date.getMonth() + 1 + '' : '0' + (date.getMonth() + 1)

                let day = date.getDate() >= 10 ? date.getDate() + '' : '0' + date.getDate()

                let hh = date.getHours() >= 10 ? date.getHours() + '' : '0' + date.getHours()

                let mm = date.getMinutes() >= 10 ? date.getMinutes() + '' : '0' + date.getMinutes()

                let ss = date.getSeconds() >= 10 ? date.getSeconds() + '' : '0' + date.getSeconds()

                let time = year + month + day + hh + mm + ss;

                pdf.save(fileName + time + '.pdf');

            }

        });

    };

用法

// html

<div class="export-container">

展示内容

</div>

// js

exportPDF('.export-container', '活动量');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用C#实现生成PDF文档(附源码) 收藏 //write by wenhui.org using System; using System.IO; using System.Text; using System.Collections; namespace PDFGenerator { public class PDFGenerator { static float pageWidth = 594.0f; static float pageDepth = 828.0f; static float pageMargin = 30.0f; static float fontSize = 20.0f; static float leadSize = 10.0f; static StreamWriter pPDF=new StreamWriter("E:\myPDF.pdf"); static MemoryStream mPDF= new MemoryStream(); static void ConvertToByteAndAddtoStream(string strMsg) { Byte[] buffer=null; buffer=ASCIIEncoding.ASCII.GetBytes(strMsg); mPDF.Write(buffer,0,buffer.Length); buffer=null; } static string xRefFormatting(long xValue) { string strMsg =xValue.ToString(); int iLen=strMsg.Length; if (iLen<10) { StringBuilder s=new StringBuilder(); int i=10-iLen; s.Append('0',i); strMsg=s.ToString() + strMsg; } return strMsg; } static void Main(string[] args) { ArrayList xRefs=new ArrayList(); //Byte[] buffer=null; float yPos =0f; long streamStart=0; long streamEnd=0; long streamLen =0; string strPDFMessage=null; //PDF文档头信息 strPDFMessage="%PDF-1.1 "; ConvertToByteAndAddtoStream(strPDFMessage); xRefs.Add(mPDF.Length); strPDFMessage="1 0 obj "; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="<> "; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="stream "; ConvertToByteAndAddtoStream(strPDFMessage); ////////PDF文档描述 streamStart=mPDF.Length; //字体 strPDFMessage="BT /F0 " + fontSize +" Tf "; ConvertToByteAndAddtoStream(strPDFMessage); //PDF文档实体高度 yPos = pageDepth - pageMargin; strPDFMessage=pageMargin + " " + yPos +" Td " ; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage= leadSize+" TL " ; ConvertToByteAndAddtoStream(strPDFMessage); //实体内容 strPDFMessage= "(http://www.wenhui.org)Tj " ; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage= "ET "; ConvertToByteAndAddtoStream(strPDFMessage); streamEnd=mPDF.Length; streamLen=streamEnd-streamStart; strPDFMessage= "endstream endobj "; ConvertToByteAndAddtoStream(strPDFMessage); //PDF文档的版本信息 xRefs.Add(mPDF.Length); strPDFMessage="2 0 obj "+ streamLen + " endobj "; ConvertToByteAndAddtoStream(strPDFMessage); xRefs.Add(mPDF.Length); strPDFMessage="3 0 obj <> endobj "; ConvertToByteAndAddtoStream(strPDFMessage); xRefs.Add(mPDF.Length); strPDFMessage="4 0 obj <</Type /Pages /Count 1 "; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="/Kids[ 3 0 R ] "; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="/Resources<</ProcSet[/PDF/Text]/Font<> >> "; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="/MediaBox [ 0 0 "+ pageWidth + " " + pageDepth + " ] >> endobj "; ConvertToByteAndAddtoStream(strPDFMessage); xRefs.Add(mPDF.Length); strPDFMessage="5 0 obj <> endobj "; ConvertToByteAndAddtoStream(strPDFMessage); xRefs.Add(mPDF.Length); strPDFMessage="6 0 obj <> endobj "; ConvertToByteAndAddtoStream(strPDFMessage); streamStart=mPDF.Length; strPDFMessage="xref 0 7 0000000000 65535 f "; for(int i=0;i<xRefs.Count;i++) { strPDFMessage+=xRefFormatting((long) xRefs[i])+" 00000 n "; } ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="trailer <> "; ConvertToByteAndAddtoStream(strPDFMessage); strPDFMessage="startxref " + streamStart+" %%EOF "; ConvertToByteAndAddtoStream(strPDFMessage); mPDF.WriteTo(pPDF.BaseStream); mPDF.Close(); pPDF.Close(); } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值