码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端实现页面内容的截图与下载(html2canvas)


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

    👇👇👇

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

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

    1.安装并引入html2canvas

    npm install html2canvas
    import html2canvasfrom 'html2canvas'

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

    以便原生js引入

    <script type="text/javascript" src=".\html2canvas.js">script>

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

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

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

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

    以上三步代码示例如下👇

    1. let aimPart = document.querySelector('.app');
    2. html2canvas(aimPart,{
    3. scale: 2,
    4. width: aimPart.offsetWidth,
    5. height: aimPart.offsetHeight,
    6. allowTaint: true, // 允许污染画布
    7. proxy: '/imgProxy'
    8. }).then((canvas) => {
    9. let imgUrl = canvas.toDataURL('image/png', 1);
    10. let downLoadLink = document.createElement('a');
    11. downLoadLink.innerText = '下载'
    12. downLoadLink.download = '铸剑山庄.png';
    13. downLoadLink.href = imgUrl;
    14. downLoadLink.className = "downLoadLink"
    15. downLoadLink.style.display = "none";
    16. // 下载图片
    17. aimPart.appendChild(downLoadLink)
    18. window.setTimeout(() => {
    19. document.querySelector('.downLoadLink').dispatchEvent(new MouseEvent('click'));
    20. aimPart.removeChild(document.querySelector('.downLoadLink'))
    21. },500)
    22. })

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

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

  • 相关阅读:
    安装linux子系统以及配置环境
    【通信系列4 -- 基站定位】
    人工智能如何管理实时视频流
    学习笔记【Java 虚拟机③】类加载与字节码技术
    项目管理中,进度管理是决定成败的关键因素!(建议收藏)
    java计算机毕业设计ETC用户自驾游推荐系统MyBatis+系统+LW文档+源码+调试部署
    【MySQL从0到1】第六篇:内置函数
    前端工程师-----HTML篇(引用牛客)
    如何在一台电脑上安装两个mysql
    创建2个线程并执行(STL/Windows/Linux)
  • 原文地址:https://blog.csdn.net/qq_58174484/article/details/134468956
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号