[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


留言

這個網誌中的熱門文章

[Visual Studio]位於網際網路或是限制區域上 或是檔案上標有 web 字樣 所以無法處理該檔案。若希望處理這些檔案 請移除 web 字樣。

[IIS] IIS執行時,發生拒絕存取路徑 問題

[windows] xcopy 備份至 「網路磁碟機」