前端实现页面内容的截图与下载(html2canvas)

今天是一个发文的好日子😀~

👇👇👇

一个需求,要截取页面中的内容并截图保存,来看一看我是怎么实现的吧:

这里需要使用到插件--html2canvas

1.安装并引入html2canvas

复制代码
npm install html2canvas
javascript 复制代码
import html2canvasfrom 'html2canvas'

也可以从这里找到相应的文件html2canvas.hertzen.com/dist/html2canvas.js

以便原生js引入

html 复制代码
<script type="text/javascript" src=".\html2canvas.js"></script>

2.创建(下载按钮)点击事件:

(1)html2canvas方法来获取canvas对象,其第一个参为对应的节点,第二个是相关配置项。

(2)获取到canvas后用其toDataURL方法转换为url,并提供a链接的href(放链接)与download(文件名)并添加到页面上来进行下载(注意图片格式统一)。

(3)想要自动下载,可先将a链接藏起来,并异步使用dispatchEvent触发其点击事件,最后移除该a链接即可。

以上三步代码示例如下👇

javascript 复制代码
let aimPart = document.querySelector('.app');
  html2canvas(aimPart,{
    scale: 2,
    width: aimPart.offsetWidth,
    height: aimPart.offsetHeight,
    allowTaint: true,    // 允许污染画布
    proxy: '/imgProxy'
  }).then((canvas) => {
    let imgUrl = canvas.toDataURL('image/png', 1);

    let downLoadLink = document.createElement('a');
    downLoadLink.innerText = '下载'
    downLoadLink.download = '铸剑山庄.png';
    downLoadLink.href = imgUrl;
    downLoadLink.className = "downLoadLink"
    downLoadLink.style.display = "none";

      // 下载图片
      aimPart.appendChild(downLoadLink)
      window.setTimeout(() => {
        document.querySelector('.downLoadLink').dispatchEvent(new MouseEvent('click'));
        aimPart.removeChild(document.querySelector('.downLoadLink'))
      },500)

  })

之后便可以下载目标节点(示例中aimPart)的相应截图了~

希望本文会对您有所帮助~ ^_^

相关推荐
haaaaaaarry14 分钟前
Element Plus常见基础组件(二)
开发语言·前端·javascript
xyphf_和派孔明39 分钟前
关于echarts的性能优化考虑
前端·性能优化·echarts
PyHaVolask1 小时前
HTML 表单进阶:用户体验优化与实战应用
前端·javascript·html·用户体验
A了LONE1 小时前
cv弹窗,退款确认弹窗
java·服务器·前端
AntBlack2 小时前
闲谈 :AI 生成视频哪家强 ,掘友们有没有推荐的工具?
前端·后端·aigc
花菜会噎住2 小时前
Vue3核心语法进阶(computed与监听)
前端·javascript·vue.js
花菜会噎住3 小时前
Vue3核心语法基础
前端·javascript·vue.js·前端框架
全宝3 小时前
echarts5实现地图过渡动画
前端·javascript·echarts
vjmap3 小时前
MCP协议:CAD地图应用的AI智能化解决方案(唯杰地图MCP)
前端·人工智能·gis
simple_lau3 小时前
鸿蒙设备如何与低功耗蓝牙设备通讯
前端