21

我知道它之前已经在这里讨论过,但是我没有找到实用的解决方案/解决方法,我希望有人知道如何解决这个问题!

这是它:

如果您尝试window.print()在谷歌浏览器的单个页面中频繁调用方法(就像用户单击打印按钮),浏览器会在控制台中抛出警告消息,说明:

忽略对 print() 的过于频繁的调用

什么也没有发生!几秒钟后,一切恢复正常,并在您window.print()再次调用命令时出现打印对话框!更糟糕的是,优秀的 Chrome 开发人员对调用打印命令的页面使用指数等待时间,这意味着用户点击按钮打印的次数越多,他等待打印对话框出现的时间就越长!

这个问题已经在 chrome 中存在了很长一段时间(14 个后续版本),并且被确认是一个Area-UI错误,我昨天再次为谷歌团队发布了它,希望 Chrome 团队的人可以验证这个令人难以置信的烦人功能何时会得到修复!

但是,我在这里寻找的是解决此问题的方法,我能做些什么来使它正常工作吗我的公司正在开发一个高度交易的财务系统,其中包含许多需要打印的报告,而仅仅因为这个小故障,整个项目就有可能在我最喜欢的谷歌 Chrome 浏览器中运行!

更新:

这是导致此功能的 Chrome 浏览器中的代码,看起来至少需要 2 秒才能有人再次调用打印命令,因此 UI 中 2 秒间隔的计时器可能会阻止进入无限等待回调!还有其他想法吗?

4

6 回答 6

19

您可以有条件地替换该window.print()功能:

// detect if browser is Chrome
if(navigator.userAgent.toLowerCase().indexOf("chrome") >  -1) {
    // wrap private vars in a closure
    (function() {
        var realPrintFunc = window.print;
        var interval = 2500; // 2.5 secs
        var nextAvailableTime = +new Date(); // when we can safely print again

        // overwrite window.print function
        window.print = function() {
            var now = +new Date();
            // if the next available time is in the past, print now
            if(now > nextAvailableTime) {
                realPrintFunc();
                nextAvailableTime = now + interval;
            } else {
                // print when next available
                setTimeout(realPrintFunc, nextAvailableTime - now);
                nextAvailableTime += interval;
            }
        }
    })();
}

您可以使用内部安全计时器/包装器,而不是使用外部安全计时器/包装器。只需添加它并window.print在 Chrome 和其他任何地方正常运行即可。(另外,闭包意味着realPrintFunc,interval并且nextAvailableTime是新的私有的window.print

如果您需要协调window.print多个框架页面之间的调用,您可以nextAvailableTime在父页面中设置,而不是在闭包中,以便所有框架都可以使用window.parent.nextAvailableTime.

于 2012-05-04T17:54:12.423 回答
4

我一直遇到同样的问题,对我来说最直接的解决方案就是创建一个新窗口,写下我需要的内容,关闭它,然后打印它。我不必处理 Chrome 的限制,因为我将其更改为以这种方式工作,并且我不需要进行任何跟踪。

print_window= window.open();
print_window.document.write(print_css + divToPrint[0].outerHTML+"</html>");
print_window.document.close();
print_window.focus();
print_window.print();
print_window.close();
于 2012-05-14T00:15:58.810 回答
1

window.print()我的解决方案是不那么频繁地打电话。您可以尝试包装window.print()到您自己的方法中,并在再次执行之前放置一个必须经过的最小时间间隔window.print()。您可以在 UI 中进行某种更改/动画,以表明工作正在完成。

“在职的”

除非您认为它真的认为每秒/每隔几秒按一次以上打印按钮会有所帮助?我的意思是,如果window.print()操作需要那么长时间,那不是您的代码错误,无论如何,UI 中都应该有一个“等待并耐心等待”的指示器。

于 2012-05-04T12:42:38.513 回答
1

如果您的所有打印机都与网络兼容,您可以更改单击打印按钮时发生的情况。除了打印页面,您的应用程序可以向服务器发送一个请求,其中包含要打印的页面的 URL 以及要打印的打印机的信息。

然后服务器手动启动打印过程,中间不会有浏览器,这可能会阻止您这样做。

于 2012-05-04T16:42:07.093 回答
1

我看到提到这个问题的所有地方都建议使用计时器。但是他们没有解决问题,我觉得 Kamyar 是唯一真正阅读源代码并理解问题的人,所以我想知道他为什么接受他所做的答案。

主要问题是 Chrome 中的延迟时间是指数级的,因此为了让这些计时器工作,它们的延迟也必须在每次使用时增加,这当然会很快变得非常烦人。Chrome 实际上只在取消打印请求后应用延迟,但我们无法检测打印是否成功。

Abathur 的解决方案实际上比您预期的要好得多。我不确定我是否会使用它,但它确实有效。

好消息:

1) 在更新的 Chrome 版本中,延迟实际上减少了。它现在去:[2, 2, 2, 4, 8, 16, 32, 32, ...]

2) 8 月 28 日有人处理了这个问题:http ://code.google.com/p/chromium/issues/detail?id=50186如果你想解决这个问题,请给它加星标。

于 2012-09-15T20:43:25.947 回答
1

没有更多的变通办法!如果我没记错的话,作为 v.23 的一部分修复的错误。

因此,如果发布周期是每 6 周,并且 Chrome 22 于 9 月 25 日发布,那么到 11 月 6 日(大约)修复将在 Chrome 稳定版中

于 2012-10-15T14:15:24.433 回答