我是 printThis 的作者,这是一个用于打印的 jquery 插件。
https://github.com/jasonday/printThis
我有一个用户提出了一个问题,我无法破解,不幸的是,我无法共享页面(隐私问题)。
在用户的站点上,问题出现在 IE 中的某些页面上,但在其他页面上没有。打印失败,因为 iframe 仍然是空的。
IE 中的错误在 jQuery 中:
contents: function (a) {
            return f.nodeName(a,
                "iframe") ? a.contentDocument || a.contentWindow.document : f.makeArray(a.childNodes)
        }
使用日志记录,我能够确定它在这条线上失败了:
var $doc = $("#" + strFrameName).contents();
但同样,这只发生在某些页面上,我无法在该用户站点之外的任何情况下重新创建。
我的问题:这里有更好的方法吗?还是一种使$doc物体更防弹的方法?
// -----------------------------------------------------------------------
// printThis v1.1
// Printing plug-in for jQuery
//
// Resources (based on) :
//              jPrintArea: http://plugins.jquery.com/project/jPrintArea
//              jqPrint: https://github.com/permanenttourist/jquery.jqprint
//              Ben Nadal: http://www.bennadel.com/blog/1591-Ask-Ben-Print-Part-Of-A-Web-Page-With-jQuery.htm
//
// Dual licensed under the MIT and GPL licenses:
//              http://www.opensource.org/licenses/mit-license.php
//              http://www.gnu.org/licenses/gpl.html
//
// (c) Jason Day 2012
//
// Usage:
//
// $("#mySelector").printThis({
//      debug: false, //show the iframe for debugging
//      importCSS: true, // import page CSS
//      printContainer: true, // grab outer container as well as the contents of the selector
//      loadCSS: "path/to/my.css" //path to additional css file
//  });
//
// Notes:
//  - the loadCSS option does not need @media print
//------------------------------------------------------------------------
(function($) {
    var opt;
    $.fn.printThis = function (options) {
        opt = $.extend({}, $.fn.printThis.defaults, options);
        var $element = (this instanceof jQuery) ? this : $(this);
    // if Opera, open a new tab
        if ($.browser.opera)
        {
            var tab = window.open("","Print Preview");
            tab.document.open();
        }
    // add dynamic iframe to DOM
        else
        {
        var strFrameName = ("printThis-" + (new Date()).getTime());
            var $iframe = $("<iframe id='" + strFrameName +"' src='about:blank'/>");
            if (!opt.debug) { $iframe.css({ position: "absolute", width: "0px", height: "0px", left: "-600px", top: "-600px" }); }
            $iframe.appendTo("body");
        }
    // allow iframe to fully render before action
    setTimeout ( function () {
        if ($.browser.opera)
            {
        var $doc = tab.document;
        } else
        {
        var $doc = $("#" + strFrameName).contents();
        }
        // import page css
        if (opt.importCSS)
        {
                $("link[rel=stylesheet]").each(function(){
                var href = $(this).attr('href');
                if(href){
                        var media = $(this).attr('media') || 'all';
                        $doc.find("head").append("<link type='text/css' rel='stylesheet' href='" + href + "' media='"+media+"'>");
                    }
        });
        }
        // add another stylesheet
        if (opt.loadCSS)
        {
        $doc.find("head").append("<link type='text/css' rel='stylesheet' href='" + opt.loadCSS + "'>");
        }
        //add title of the page
        if (opt.titlePage)
        {
        $doc.find("head").append('<title>'+opt.titlePage+'</title>');
        } 
        //grab outer container
        if (opt.printContainer) { $doc.find("body").append($element.outer()); }
        else { $element.each( function() { $doc.find("body").append($(this).html()); }); }
        //$doc.close();
        // print
        ($.browser.opera ? tab : $iframe[0].contentWindow).focus();
        setTimeout( function() { ($.browser.opera ? tab : $iframe[0].contentWindow).print(); if (tab) { tab.close(); } }, 1000);
        //removed iframe after 60 seconds
        setTimeout(
        function(){
        $iframe.remove();
        },
        (60 * 1000)
        );
    }, 333 );
    }
    $.fn.printThis.defaults = {
        debug: false, //show the iframe for debugging
        importCSS: true, // import page CSS
        printContainer: true, // grab outer container as well as the contents of the selector
        loadCSS: "", //path to additional css file
        titlePage: "" //add title to print page
    };
    jQuery.fn.outer = function() {
      return $($('<div></div>').html(this.clone())).html();
    }
})(jQuery);
更新
问题由于document.domain
此类页面已document.domain设置且 IE 不document.domain从父级继承。
为了修复该部分,我将 iframe 创建更改为标准 javascript,并将源设置为在 iframe 创建时写入document.domain。
    var printI= document.createElement('iframe');
    printI.name = "printIframe";
    printI.id = strFrameName;
    document.body.appendChild(printI);
    printI.src = "javascript:document.write('<head><script>document.domain=\"mydomain.com\";</script></head><body></body>')";
   var $iframe = $("#" + strFrameName);
所以这修复了访问被拒绝,但是现在框架不会打印。我已经尝试了很多不同的方法来访问该对象,但是它们都不起作用。
A)在这种情况下您将如何访问框架(我已经尝试过 SO 中概述的大多数方法)以使 IE 识别和打印
或者
B) 谁能想到一个更好的方法来让 document.domain 在使用 jQuery 创建时进入 iframe?(以后不能,因为会出现访问被拒绝的问题)