使用javascript在网页上打印单张图片

14167次阅读 1093人点赞 作者: WuBin 发布时间: 2022-08-19 10:24:01
扫码到手机查看

如何打印网页

首先来看我们最终实现的效果:http://code.wubin.work/code/js/iframe-print-img/

在浏览器中,我们可以通过点击菜单打印项来打印整个页面。或者你可以使用快捷键 Ctrl + P(Command + P) 来打印页面。

在代码中,可以使用window.print()方法调用页面打印。

以上 3 种方式,都会打印整个页面。

今天这篇文章将会介绍,如何通过 JavaScript 单独打印网页的中的图片元素?

实现方案

到,window.print()方法会调用页面打印,但这时候打印的是整个页面。

如果需要在网页中打印单张图片,我们需要借助 iframe 的能力。把图片插入到 iframe 内,然后再调用 iframe 的print()方法,这样打印的就是 iframe 的内容,而不是当前页面。

我们先创建 HTML 结构:

<img id="image" src="/path/to/image.jpg" />
<button id="print">打印</button>

我们希望通过点击打印按钮触发页面打印,所以我们需要在按钮上添加click事件。

const printBtn = document.getElementById('print');

printBtn.addEventListener('click', function () {
  // ...
});

创建 iframe 元素

接下来,我们通过 JavaScript 创建一个 iframe 元素。

const iframe = document.createElement('iframe');

// iframe 不展示在页面
iframe.style.height = 0;
iframe.style.visibility = 'hidden';
iframe.style.width = 0;

// 设置 iframe 内容
iframe.setAttribute('srcdoc', '<html><body></body></html>');

document.body.appendChild(iframe);

我们可以使用setAttribute方法,给 iframe 设置初始化文档内容。

上面的代码示例中,我们在新创建的 iframe 内只添加了简单的 html 和 body 元素。

在 iframe 内插入图片

虽然我们刚创建的 iframe 是个简单的 html 内容,而不是 URL 链接。我们仍然需要等待 iframe 加载完成之后,才能再往 iframe 内插入图片元素。

iframe.addEventListener('load', function () {
  // 克隆页面的图片元素
  const image = document.getElementById('image').cloneNode();
  image.style.maxWidth = '100%';

  // 把克隆的图片元素添加到 iframe 内
  const body = iframe.contentDocument.body;
  body.style.textAlign = 'center';
  body.appendChild(image);
});

监听 iframe 的 load 事件,在其回调函数中克隆当前页面的图片,然后插入到 iframe 文档内。

打印图片

同样,我们需要等到图片加载完成之后,再去调用 iframe 的print()方法,打印出图片。

iframe.addEventListener('load', function () {
  // ...
  image.addEventListener('load', function () {
    iframe.contentWindow.print();
  });
});

等到图片加载完成,同样也是监听图片的 load 事件。

在页面中调用 iframe 的print()方法,需要使用iframe.contentWindow属性。

删除 iframe

打印完成结束后,我们刚创建的 iframe 元素也就没有用了,所以我们要把它删除掉。

iframe.contentWindow.addEventListener('afterprint', function () {
  // 通过父级页面删除 iframe 自己
  iframe.parentNode.removeChild(iframe);
});

打印完成,即监听iframe.contentWindow元素的afterprint事件。在回调函数内,通过iframe.parentNode也就是父级页面元素移除 iframe 自身。

点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:iframe,打印网页
推荐阅读
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    9119次阅读 589人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • Vue

    盘点Vue2和Vue3的10种组件通信方式

    Vue中组件通信方式有很多,其中Vue2和Vue3实现起来也会有很多差异;本文将通过选项式API组合式API以及setup三种不同实现方式全面介绍Vue2和Vue3的组件通信方式。

    3884次阅读 289人点赞 发布时间: 2022-08-19 09:40:16 立即查看
  • JS

    几个高级前端常用的API

    推荐4个前端开发中常用的高端API,分别是MutationObserver、IntersectionObserver、getComputedstyle、getBoundingClientRect、requ...

    14139次阅读 919人点赞 发布时间: 2021-11-11 09:39:54 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    12947次阅读 445人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    11539次阅读 926人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    15646次阅读 1248人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    14843次阅读 1209人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    29040次阅读 2281人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    25064次阅读 1931人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录