[英]Print PDF File in Javascript using Iframe
這是我的代碼,用於使用iframe在JavaScript中打印pdf文件。 但是我無法打印任何內容,但是此代碼在谷歌chrome瀏覽器中運行正常。 在IE8中無法正常運作。 ContentLoaderDiv是html部門。 請幫我..
當我從使用Java腳本而不是Adobe Reader打印對話框進行打印的應用程序中打印PDF文檔時,將調用瀏覽器打印對話框。
有沒有人看過這個問題? 如何調用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();
}
試試這個:
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方法使它更易於維護和/或重用。 為了滿足您的所有需求,可能仍需要對實際邏輯進行一些修改。
我一直在努力尋找一種適用於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);
});
...干杯。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.