printJS的onPrintDialogClose回调函数不执行?

在点击打印按钮时,跳出打印的预览界面,此时点击取消打印。我们需要做一些事情,比如页面样式的改动,页面标题的还原(document.title)。需要用到onPrintDialogClose的回调方法。我们直接加上去是不执行或者需要来回切换页面(让页面重新聚焦)才会执行onPrintDialogClose的方法。

解决:我们要借助window.dispatchEvent的方法来触发事件。这里不是使用自定义事件,而是new一个新的聚焦事件。然后在回调中取消这个计时器。

我的理解就是(打印预览界面出来后按了取消按钮,此时页面没用聚焦回来。所以没用执行onPrintDialogClose函数。我只需要在点击打印按钮时,利用定时器不断执行window.dispatchEvent来触发聚焦事件,这样我的页面是一直聚焦状态的,然后在回调函数中清楚定时器即可。)

 参考贴:自定义事件的触发 dispatchEvent 的用法_EncodingAESKey的博客-CSDN博客_dispatcheventwindow.addEventListener && window.dispatchEvent一、标准浏览器提供了可供元素触发的方法:element.dispatchEvent(),在使用之前,需要创建和初始化,下面是具体的用法:vue中举例:1.通过 var event = document.createEvent("HTMLEvents"); 这个方法创建一个eve...https://blog.csdn.net/weixin_42333548/article/details/103367725

Vue+Print.js配置与onPrintDialogClose无效问题处理 - sonicyard - 博客园日常配置: npm install print-js --save 在需要打印的页面引入 import printJS from "print-js" 示例与onPrintDialhttps://www.cnblogs.com/sonicyard/p/14333535.html

解答有限,有更好的解释望大家不惜精力,帮助我更好理解。谢谢!

 

  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值