[JQuery]列印包含css 的div-jqprint
在開發網站的時候很常會遇到需要印列頁面的需求,以往常用的做法是在列印時,將不想列印的部分隱藏,或者另開一個頁面直接將想列印的部分的html寫入並列印,不過這些做法都很麻煩,而且會有css引用的問題,導致跑版之類的。
所以今天想介紹一下「jqprint」,在開發上真的會方便很多。
範例:
1.html code(拿「傳統」作法跟「jqprint」做個比較)
<table class="table table-bordered landTable tabbleNarrow table-center table-vert-center" id="PrintDiv">
<tr>
<td>Test1</td>
<td>Test2</td>
</tr>
</table>
<button onclick="NormalPrint()">NormalPrint</button>
<button onclick="JQueryPrint()">JQueryPrint</button>
@section scripts
{
<script src="~/Scripts/custom/jqprint.js"></script>
<script>
function NormalPrint() {
w = window.open();
w.document.write($('#PrintDiv').html());
w.print();
w.close();
}
function JQueryPrint() {
$("#PrintDiv").jqprint();
}
</script>
}
2.jqprint.js檔案內容
// -----------------------------------------------------------------------
// Eros Fratini - eros@recoding.it
// jqprint 0.3
//
// - 19/06/2009 - some new implementations, added Opera support
// - 11/05/2009 - first sketch
//
// Printing plug-in for jQuery, evolution of jPrintArea: http://plugins.jquery.com/project/jPrintArea
// requires jQuery 1.3.x
//
// Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
//------------------------------------------------------------------------
//solve Cannot read properties of undefined (reading 'opera') issue
jQuery.browser = {};
(function () {
jQuery.browser.msie = false;
jQuery.browser.version = 0;
if (navigator.userAgent.match(/MSIE ([0-9]+)./)) {
jQuery.browser.msie = true;
jQuery.browser.version = RegExp.$1;
}
})();
(function ($) {
var opt;
$.fn.jqprint = function (options) {
opt = $.extend({}, $.fn.jqprint.defaults, options);
var $element = (this instanceof jQuery) ? this : $(this);
if (opt.operaSupport && $.browser.opera) {
var tab = window.open("", "jqPrint-preview");
tab.document.open();
var doc = tab.document;
}
else {
var $iframe = $("<iframe />");
if (!opt.debug) { $iframe.css({ position: "absolute", width: "0px", height: "0px", left: "-600px", top: "-600px" }); }
$iframe.appendTo("body");
var doc = $iframe[0].contentWindow.document;
}
if (opt.importCSS) {
if ($("link[media=print]").length > 0) {
$("link[media=print]").each(function () {
doc.write("<link type='text/css' rel='stylesheet' href='" + $(this).attr("href") + "' media='print' />");
});
}
else {
$("link").each(function () {
doc.write("<link type='text/css' rel='stylesheet' href='" + $(this).attr("href") + "' />");
});
}
}
if (opt.printContainer) { doc.write($element.outer()); }
else { $element.each(function () { doc.write($(this).html()); }); }
doc.close();
(opt.operaSupport && $.browser.opera ? tab : $iframe[0].contentWindow).focus();
setTimeout(function () { (opt.operaSupport && $.browser.opera ? tab : $iframe[0].contentWindow).print(); if (tab) { tab.close(); } }, 1000);
}
$.fn.jqprint.defaults = {
debug: false,
importCSS: true,
printContainer: true,
operaSupport: true
};
// Thanks to 9__, found at http://users.livejournal.com/9__/380664.html
jQuery.fn.outer = function () {
return $($('<div></div>').html(this.clone())).html();
}
})(jQuery);
3.結果
(1)NormalPrint
(2)JQueryPrint
留言
張貼留言