js实现浏览器的打印功能——路径打印

简介: js实现浏览器的打印功能——路径打印

或多或少在前端页面开发的过程中会遇到一些网页需要这样的功能——打印页面,没错,就是页面打印,那个window.print的功能,但是怎么才能写一个又好用又不会有太多问题和性能的打印用能的,那个他来了(引用了element-ui的消息提示组件$message做消息提示)

printReport () {
      if (!this.reportUrl) { // 用来判断打印的地址是否存在,你们随意,我的是业务需要
        this.$message.error('等待报告加载完成,请稍后重试')
      }
      this.$message.warning('正在唤起打印服务请稍等'); // 自己的提示语,你们随便
      if (this.reportStart) return;
      this.reportStart = true;
      var iframe = window.document.createElement('iframe');
      try {
        iframe.id = 'print_iframe';
        iframe.style = "position: absolute;top: 0;left: 0;z-index:-1;display:none";
        document.body.appendChild(iframe);
        let ifr = window.frames["print_iframe"].contentDocument;
        let ifrImage = window.document.createElement('img');
        ifrImage.src = this.reportUrl;
        ifr.body.style = "margin:0px"
        ifr.body.append(ifrImage);
        let ifrImageObj = new Image();
        ifrImageObj.src = this.reportUrl;
        ifrImageObj.onload = () => {
          window.frames["print_iframe"].contentWindow.print();
          document.body.removeChild(window.frames["print_iframe"]);  //打印之后记得移除dom,避免内存溢出
          this.reportStart = false;
        }
      } catch (error) {
        iframe.setAttribute("id", "print_iframe");
        iframe.setAttribute("style", "position: absolute;top: 0;left: 0;z-index:9999;display:none");
        window.document.body.appendChild(iframe);
        let ifr = window.frames["print_iframe"].contentWindow || window.frames["print_iframe"];
        let ifrImage = window.document.createElement('img');
        ifrImage.src = this.reportUrl;
        ifr.document.body.setAttribute("style", "margin:0px;size: portrait;");
        ifr.document.body.appendChild(ifrImage);
        let ifrImageObj = new Image();
        ifrImageObj.src = this.reportUrl;
        ifrImageObj.onload = () => {
          ifr.window.focus();
          ifr.window.print();
          window.document.body.removeChild(document.getElementById('print_iframe'));
          this.reportStart = false;
        }
      }
    }
结束语:关注我,少走弯路!

image.png

相关文章
|
6天前
|
Web App开发 JavaScript 前端开发
添加浮动按钮点击滚动到网页底部的纯JavaScript演示代码 IE9、11,Maxthon 1.6.7,Firefox30、31,360极速浏览器7.5.3.308下测试正常
添加浮动按钮点击滚动到网页底部的纯JavaScript演示代码 IE9、11,Maxthon 1.6.7,Firefox30、31,360极速浏览器7.5.3.308下测试正常
|
7天前
|
JavaScript 前端开发
js之浏览器对象|28
js之浏览器对象|28
|
9天前
|
JavaScript
Vue3基础(19)___vite.config.js中配置路径别名
本文介绍了如何在Vue 3的Vite配置文件`vite.config.js`中设置路径别名,以及如何在页面中使用这些别名导入模块。
13 0
Vue3基础(19)___vite.config.js中配置路径别名
用html+javascript打造公文一键排版系统14:为半角和全角字符相互转换功能增加英文字母、阿拉伯数字、标点符号、空格选项
用html+javascript打造公文一键排版系统14:为半角和全角字符相互转换功能增加英文字母、阿拉伯数字、标点符号、空格选项
|
4天前
|
存储 文字识别 前端开发
用html+javascript打造公文一键排版系统13:增加半角字符和全角字符的相互转换功能
用html+javascript打造公文一键排版系统13:增加半角字符和全角字符的相互转换功能
|
2月前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
33 1
|
2月前
|
编解码 JavaScript 前端开发
JS逆向浏览器脱环境专题:事件学习和编写、DOM和BOM结构、指纹验证排查、代理自吐环境通杀环境检测、脱环境框架、脱环境插件解决
JS逆向浏览器脱环境专题:事件学习和编写、DOM和BOM结构、指纹验证排查、代理自吐环境通杀环境检测、脱环境框架、脱环境插件解决
58 1
|
2月前
|
开发者 Android开发 iOS开发
Xamarin开发者的神器!揭秘你绝不能错过的插件和工具,让你的开发效率飞跃式提升
【8月更文挑战第31天】Xamarin.Forms 是一个强大的框架,让开发者通过单一共享代码库构建跨平台移动应用,支持 iOS、Android 和 Windows。使用 C# 和 XAML,它简化了多平台开发流程,保持一致的用户体验。本指南通过创建一个简单的 “HelloXamarin” 应用介绍 Xamarin.Forms 的基本功能和工作原理。首先配置 Visual Studio 开发环境,然后创建并运行一个包含标题、按钮和消息标签的示例应用,展示如何定义界面布局及处理按钮点击事件。这帮助开发者快速入门 Xamarin.Forms,提高跨平台应用开发效率。
33 0
|
2月前
|
API UED 开发者
如何在Uno Platform中轻松实现流畅动画效果——从基础到优化,全方位打造用户友好的动态交互体验!
【8月更文挑战第31天】在开发跨平台应用时,确保用户界面流畅且具吸引力至关重要。Uno Platform 作为多端统一的开发框架,不仅支持跨系统应用开发,还能通过优化实现流畅动画,增强用户体验。本文探讨了Uno Platform中实现流畅动画的多个方面,包括动画基础、性能优化、实践技巧及问题排查,帮助开发者掌握具体优化策略,提升应用质量与用户满意度。通过合理利用故事板、减少布局复杂性、使用硬件加速等技术,结合异步方法与预设缓存技巧,开发者能够创建美观且流畅的动画效果。
57 0
|
2月前
|
JavaScript 前端开发 开发者
Vue.js的未来已来:掌握最新功能,驾驭前端开发的新浪潮!
【8月更文挑战第30天】Vue.js作为前端开发领域的明星框架,凭借其轻量级、响应式及组件化特性,深受全球开发者喜爱。它持续进化,引入新功能并优化性能,如提升渲染速度和减小打包体积,增强TypeScript支持,简化组件编写流程,进一步提升应用响应性和加载速度,改善开发者体验。活跃的社区和丰富的开源项目如“vuejs-challenges”推动其不断发展。未来,Vue.js将探索更多新特性,如宏和非虚拟DOM模式,巩固其在现代前端框架中的领先地位。
44 0
下一篇
无影云桌面