这是我使用iframe在JavaScript中打印pdf文件的代码。但我无法打印任何事情,但这段代码完全适用于谷歌浏览器。在IE8中无法正常工作。 ContentLoaderDiv是html部门。请帮帮我..
当我从使用Java脚本打印的应用程序打印PDF文档而不是adobe Reader打印对话框时,将调用浏览器打印对话框。
有没有人见过这个问题?如何调用Adobe Reader打印机对话框而不是浏览器打印对话框?
function printPdf() {
var ContentLoaderDiv = document.getElementById('ContentLoaderDiv');
ContentLoaderDiv.innerHTML = "";
ContentLoaderDiv.innerHTML = '<div id="pdfdiv" style="position: relative;"><iframe id="frame1" height="800" width="700" src="' + document.getElementById("<%= hdnPDFPathForObject.ClientID %>").value + "print.pdf#scrollbar=1&toolbar=1&statusbar=0&messages=0&navpanes=1" + '"' + " /></iframe></div>";
frame1.focus();
frame1.print();
}
答案 0 :(得分:5)
试试这个:
function PdfUtil(url) {
var iframe;
var __construct = function(url) {
iframe = getContentIframe(url);
}
var getContentIframe = function(url) {
var iframe = document.createElement('iframe');
iframe.src = url;
return iframe;
}
this.display = function(parentDomElement) {
parentDomElement.appendChild(iframe);
}
this.print = function() {
try {
iframe.contentWindow.print();
} catch(e) {
throw new Error("Printing failed.");
}
}
__construct(url);
}
你可以按如下方式使用它:
var pdf = new PdfUtil(PDF_URL);
pdf.display(document.getElementById('placeholder'));
document.getElementById('printBtn').onclick = function() {
pdf.print();
}
显然,虽然这里的PDF_URL
是“常量”,但在你的情况下,它很可能会被生成。
与IE8和Chrome完美配合(也适用于其他浏览器)。 此外,OO方法使其更易于维护和/或可重用。可能仍需要对实际逻辑进行轻微修改以满足您的所有需求。
答案 1 :(得分:1)
我一直在努力寻找适用于IE和Chrome的解决方案。这对我有用:
$(function() {
var ua = window.navigator.userAgent;
var msie = ua.indexOf('MSIE ');
var trident = ua.indexOf('Trident/');
var edge = ua.indexOf('Edge/');
var url = '/url/to/file.pdf';
var pdf ='';
var style = 'position:fixed; top:0px; left:0px; bottom:0px; right:0px; width:100%; height:100%; border:none; margin:0; padding:0; overflow:hidden;';
if(msie > 0 || trident > 0 || edge > 0){
pdf = '<object data="' + url + '" name="print_frame" id="print_frame" style="' + style + '" type="application/pdf">';
}
else{
pdf ='<iframe src="' + url + '" name="print_frame" id="print_frame" style="' + style + '"></iframe>';
}
$(document.body).append(pdf);
setTimeout(function(){
window.frames["print_frame"].focus();
window.frames["print_frame"].print();
},2000);
});
...欢呼声。