オンロードで印刷プレビューページを起動することになっているページがあります。
私はこれを見つけました:
var OLECMDID = 7;
/* OLECMDID values:
* 6 - print
* 7 - print preview
* 1 - open window
* 4 - Save As
*/
var Prompt = 1; // 2 DONTPROMPTUSER
var WebBrowser = '<OBJECT ID="WebBrowser1" WIDTH=0 HEIGHT=0 CLASSID="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2"></OBJECT>';
document.body.insertAdjacentHTML('beforeEnd', WebBrowser);
WebBrowser1.ExecWB(OLECMDID, Prompt);
WebBrowser1.outerHTML = "";
しかし...
IEのより良い方法、またはFireFoxで機能する方法はありますか?
印刷プレビューはブラウザの機能であるため、セキュリティリスクが生じるため、JavaScriptから呼び出されないように保護する必要があります。
そのため、この例ではJavaScriptのセキュリティ問題を回避するActive Xを使用しています。
そのため、代わりに既にあるはずの印刷スタイルシートを使用し、media = printではなくmedia = screen、printに対して表示します。
Alist Apart:Going to Print を読んで、印刷スタイルシートのテーマに関する良い記事を読んでください。
クロスブラウザーJavaScriptで可能なことはwindow.print()
であると思います。これは(Firefox 3では)印刷プレビューダイアログではなく、「印刷」ダイアログを表示します。
Javascriptを使用して実行できます。 html/aspxコードが次のようになっているとします。
<span>Main heading</span>
<asp:Label ID="lbl1" runat="server" Text="Contents"></asp:Label>
<asp:Label Text="Contractor Name" ID="lblCont" runat="server"></asp:Label>
<div id="forPrintPreview">
<asp:Label Text="Company Name" runat="server"></asp:Label>
<asp:GridView runat="server">
//GridView Content goes here
</asp:GridView
</div>
<input type="button" onclick="PrintPreview();" value="Print Preview" />
「印刷プレビュー」ボタンをクリックすると、印刷用のデータを含むウィンドウが開きます。 「forPrintPreview」がdivのIDであることに注意してください。印刷プレビューの機能は次のようになります。
function PrintPreview() {
var Contractor= $('span[id*="lblCont"]').html();
printWindow = window.open("", "", "location=1,status=1,scrollbars=1,width=650,height=600");
printWindow.document.write('<html><head>');
printWindow.document.write('<style type="text/css">@media print{.no-print, .no-print *{display: none !important;}</style>');
printWindow.document.write('</head><body>');
printWindow.document.write('<div style="width:100%;text-align:right">');
//Print and cancel button
printWindow.document.write('<input type="button" id="btnPrint" value="Print" class="no-print" style="width:100px" onclick="window.print()" />');
printWindow.document.write('<input type="button" id="btnCancel" value="Cancel" class="no-print" style="width:100px" onclick="window.close()" />');
printWindow.document.write('</div>');
//You can include any data this way.
printWindow.document.write('<table><tr><td>Contractor name:'+ Contractor +'</td></tr>you can include any info here</table');
printWindow.document.write(document.getElementById('forPrintPreview').innerHTML);
//here 'forPrintPreview' is the id of the 'div' in current page(aspx).
printWindow.document.write('</body></html>');
printWindow.document.close();
printWindow.focus();
}
「印刷」ボタンと「キャンセル」ボタンにはcssクラス「印刷なし」があるため、これらのボタンは印刷に表示されません。