手写一个打印PDF方法,完美解决跨域问题

news/2024/10/19 2:15:02/

        最近在项目上遇到一个棘手的问题:系统之前的打印PDF文件功能是好的,但是换了个环境发现坏掉了( ╯□╰ ),很无语!排查问题时,代码跟之前一毛一样,本地使用是没问题的,但是到了服务器上,直接报错了。一查才发现,出现了跨域问题。跟后端沟通,后端说不知道什么问题,那还能怎么办呢,前端解决呗,研究了几天想到一个办法,记录分享一下!!!

        直接上代码:

    toPrint (row) {// 确保 filePath 存在且是有效的if (!row.filePath) {console.error('filePath is missing or invalid')return}let str = row.filePath.split('/').slice(3).join('/')let port = this.webConfig.deployType === 'NGINX' ? '' : ':8880'let url = window.location.protocol + '//' + window.location.host + port + '/api/fp/' + str// 打开一个新窗口并加载 URLconst printWindow = window.open(url, '_blank')if (printWindow) {// 等待一段时间确保新窗口内容加载完成后执行打印setTimeout(() => {if (printWindow.document.readyState === 'complete') {printWindow.print()// 关闭新窗口(可选)// printWindow.close();} else {console.error('New window did not load properly.')}}, 1000) // 1秒钟的延迟,可以根据实际情况调整时间} else {console.error('Failed to open new window for printing')}},

方法原理:

        原理其实很简单:浏览器自带预览PDF文件的功能,并且有下载按钮,我们只要想办法打开PDF文件的预览,再调用它的printWindow.print()方法,即可轻松实现打印功能。

使用方法:

        1、后端返回文件路径即可,这里我们这边预览的时候路径有要求,如果路径不一样可以根据自己的需要修改

        2、调用时,在toPrint方法里面传入一个对象,对象的filePath属性就是后端返回的服务器路径

总结:

        遇到这种跨域问题,可以问一下后端,一般都是后端处理这种问题,我解决完这个问题之后,问了其他后端,给到的反馈是后端之前解决过这种问题,只是跟我对接的这个后端不知道。

        为了避免遇到这种情况跟后端扯皮,我还是选择前端自己想办法解决算了、、、 


http://www.ppmy.cn/news/1514226.html

相关文章

Nginx: 配置项之root和alias的区别, 深入理解location, 以及stub_status模块的用法

root和alias的区别 root 和 alias 两者都是来指定我们的URI和我们磁盘文件上的一个具体静态资源文件的一个映射关系 语法结构 1 ) root 语法:root path;上下文:http server location if 2 ) alias 语法:alias path;上下文:l…

c++ opencv显示图片

项目中添加头文件&#xff0c;库不在赘述&#xff0c;这里直接上核心代码&#xff1a; #include <iostream> #include <opencv2/imgcodecs.hpp> #include <opencv2/highgui.hpp> #include <opencv2/imgproc.hpp> #include <iostream> using na…

Redis 为什么要设计成单线程?Redis 6.0 版本开始为什么变成多线程?

Redis 最初采用了单线程模型&#xff0c;这一设计决策主要是为了简化并发控制并提升性能。尽管 Redis 的单线程模型在许多场景中表现出色&#xff0c;但从 Redis 6.0 版本开始&#xff0c;引入了多线程支持以优化网络 I/O 操作。下面是单线程模型的优点和 Redis 多线程演变的详…

基于django的影音播放网站 /基于python的影视网站/影视播放系统

摘 要 随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理系统应运而生&#xff0c;各行各业相继进入信息管理时代&a…

夏季炎热,宠物化身掉毛大王,猫咪浮毛异味问题该如何解决?

最近猫咪掉毛是在太严重了&#xff0c;我以为是太久没给它洗澡了&#xff0c;下班连忙带去宠物店洗澡。结果宠物店的姐姐告诉我&#xff0c;是因为换毛季&#xff0c;这是一种正常的生理现象&#xff0c;平时多加清理就好了。我还奇怪梳毛的时候都听话不少&#xff0c;原来是太…

KT来袭,打造沉浸式体验的聚合性web3应用平台

随着步入 2024&#xff0c;漫长的区块链熊市即将接近尾声。纵观产业发展&#xff0c;逆流而上往往会是彰显品牌市场影响力和技术实力的最佳证明。在这次周期中&#xff0c;一个名为KT的web3.0聚合平台吸引了市场关注&#xff0c;无论在市场层面还是技术层面&#xff0c;都广泛赢…

前端跨域2

前端跨域2 前端跨域解决方案&#xff08;11种方案&#xff09; 1.JSONP跨域解决方案的底层原理 script、img、link、iframe...<script src"https://cdn.bootcss.com/jquery/3.4.1/core.js"></script>// 这个就是因为script标签没有跨域限制&#xff0…

EmguCV学习笔记 VB.Net 2.4 Image类

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 EmguCV学习笔记目录 Vb.net EmguCV学习笔记目录 C# 笔者的博客网址&#xff1a;VB.Net-CSDN博客 教程相关说明以及如何获得pdf教…