在文档加载时使用PDF.JS打印base64 PDF

时间:2017-04-06 20:03:03

标签: javascript pdf printing pdf.js

我正在尝试使用PDF.js打印pdf,但目前我无法获取pdf元素中呈现的文档数据。这就是它现在的样子: eg 因此,没有数据被渲染。

这是背后的代码:

<script  src="jquery-2.2.4.min.js"></script>
<script type="text/javascript" src="pdf.js"></script>
<script type="text/javascript" src="pdf.worker.js"></script>

<body id="printbody" style="margin:0px;">
</body>

<script type="text/javascript">    
        var pdfData = atob('JVBERi0xLjQK...'); //Shortened
        PDFJS.workerSrc = 'pdf.worker.js';        
        PDFJS.getDocument({data: pdfData}).then(function RenderAndPrint(res) {
            var src = URL.createObjectURL(new Blob([res], { type: 'application/pdf' }))
            var printFrame = document.createElement('iframe');
            printFrame.id = 'print-frame';
            //printFrame.style.display = 'none';
            printFrame.style.width = '100%'
            printFrame.style.height = '100%'
            printFrame.style.border = 'none'
            printFrame.src = src;
            document.body.appendChild(printFrame);
            setTimeout(function () {
            printFrame.contentWindow.print();
            }, 0)       
        });    
</script>

最终目标是通过AJAX将整个页面附加到现有页面,因此只要附加此页面并呈现PDF,iframe(将被隐藏)将立即打印pdf渲染,然后最终处置自己。

1 个答案:

答案 0 :(得分:0)

我使用的是itextsharp,而是将pdf保存到本地系统,将其设置为打开时打印如下:

PdfAction print = new PdfAction(PdfAction.PRINTDIALOG);
writer.SetOpenAction(print);

然后使用iframe通过将文件设置为src

来呈现pdf