WEB前端将指定DOM生成图片并下载最佳实践(html2canvas)
前言:
html2canvas 是一个 JavaScript 库,其主要作用是将 HTML 元素或其部分内容渲染为 Canvas 图像。通过它,开发者可以将网页中的任意 DOM 元素(包括文本、图片、样式等)转换为图片格式(如 PNG 或 JPEG),并进一步用于保存、分享或其他处理。
html2canvas 的使用:
安装html2canvas
npm install html2canvas --save
vue3示例:
完整代码:
<template><div><div class="image-box" ref="downloadRef"><div class="text">恭顺安康</div><img class="picture" src="@/assets/images/study-dog.png" alt="" /></div><el-button type="primary" plain @click="download">下载图片</el-button></div>
</template><script setup>
import { ref } from "vue";
import html2canvas from 'html2canvas'const downloadRef = ref();
const download = () => {html2canvas(downloadRef.value).then((canvas) => {let dataURL = canvas.toDataURL("image/png"); //base64格式的图片 url// 创建a标签下载图片var addElement = document.createElement("a");addElement.href = dataURL;addElement.download = "恭顺安康.png"; //设置下载的图片名称document.body.appendChild(addElement);addElement.click();document.body.removeChild(addElement);});
};
</script><style lang="less" scoped>
.image-box {width: 500px;height: 520px;border: 1px solid #ccc;background-color: aqua;display: flex;justify-content: center;align-items: center;flex-direction: column;font-weight: 700;font-size: 28px;margin-bottom: 10px;.text {color: #fff;margin-bottom: 10px;}.picture {width: 400px;height: 400px;}
}
</style>
效果演示:

我们还可以将base64格式的图片转化成file或blob格式的图片,兼容性会更好一些。完整代码如下:
<template><div><div class="image-box" ref="downloadRef"><div class="text">恭顺安康</div><img class="picture" src="@/assets/images/study-dog.png" alt="" /></div><el-button type="primary" plain @click="download">下载图片</el-button></div>
</template><script setup>
import { ref } from "vue";
import html2canvas from "html2canvas";const downloadRef = ref();const dataURLtoBlob = (dataurl) => {var arr = dataurl.split(","); //分割为数组,分割到第一个逗号let bstr = window.atob(arr[1]);let n = bstr.length;let u8arr = new Uint8Array(n);while (n--) {u8arr[n] = bstr.charCodeAt(n);}return new Blob([u8arr], { type: "png" });
};const download = () => {html2canvas(downloadRef.value).then((canvas) => {let dataURL = canvas.toDataURL("image/png"); //base64格式的图片 urlconst blobUrl = dataURLtoBlob(dataURL); //转化成blob格式的图片 Blob{size:xx,type:xx}var fileUrl = URL.createObjectURL(blobUrl); //URL.createObjectURL()创建一个指向File或Blob对象的URL。这个URL可以被用于指定一个HTML标签的href属性// 创建a标签下载图片var addElement = document.createElement("a");addElement.href = fileUrl;addElement.download = "恭顺安康.png";document.body.appendChild(addElement);addElement.click();document.body.removeChild(addElement);});
};
</script><style lang="less" scoped>
.image-box {width: 500px;height: 520px;border: 1px solid #ccc;background-color: aqua;display: flex;justify-content: center;align-items: center;flex-direction: column;font-weight: 700;font-size: 28px;margin-bottom: 10px;.text {color: #fff;margin-bottom: 10px;}.picture {width: 400px;height: 400px;}
}
</style>
效果同上~
拓展
html2canvas主要作用和应用场景?
主要作用
将 HTML 转换为图片
html2canvas 可以将网页中的特定区域或整个页面转换为图片,支持复杂的 CSS 样式(如渐变、阴影、边框等)。
示例:将网页中的某个
<div>元素转换为图片。生成截图
用于生成网页的截图,用户可以保存或分享这些截图。
示例:生成网页的缩略图或用户自定义内容的截图。
保存网页内容
将网页中的内容保存为图片格式,方便用户下载或分享。
示例:用户点击“保存为图片”按钮,将网页内容保存为 PNG 文件。
实现网页打印功能
将网页内容转换为图片后,可以用于打印或生成 PDF。
示例:将网页中的表格或图表转换为图片并打印。
动态生成图片
结合用户输入或动态数据,实时生成图片。
示例:根据用户输入生成自定义海报或证书。
跨平台兼容
在移动端和桌面端均可使用,支持主流浏览器。
示例:在移动端生成分享图片。
使用场景
网页截图工具
用户可以通过点击按钮将网页内容保存为图片。生成分享图片
在社交媒体分享时,将网页内容转换为图片,方便传播。数据可视化
将图表、地图等可视化内容保存为图片。网页内容存档
将网页内容保存为图片格式,用于存档或备份。自定义海报或证书
根据用户输入动态生成图片,如活动海报、电子证书等。
为什么blob格式的图片会比base64格式的图片兼容性更好一些?
Blob 格式的图片比 Base64 格式的图片兼容性更好,主要是因为它们在存储、传输和处理方式上的差异。以下是具体原因:
1. 文件大小
Blob:Blob 是二进制数据,存储的是文件的原始二进制形式,因此文件大小与原始图片一致,不会额外增加体积。
Base64:Base64 是一种文本编码方式,它将二进制数据转换为 ASCII 字符串,会导致数据体积增加约 33%。这会增加内存占用和传输开销。
兼容性影响:
对于大图片或大量图片,Base64 会增加内存和网络负担,可能导致性能问题,而 Blob 则更高效。
2. 数据传输效率
Blob:Blob 是二进制数据,适合直接用于网络传输(如通过
fetch或XMLHttpRequest上传或下载),传输效率高。Base64:Base64 是文本格式,传输时需要额外的编码和解码步骤,效率较低。
兼容性影响:
在网络传输中,Blob 格式更高效,尤其是在移动端或网络环境较差的情况下。
3. 浏览器处理方式
Blob:Blob 是浏览器原生支持的二进制数据格式,可以直接用于图片渲染、文件下载等操作,兼容性更好。
Base64:Base64 需要浏览器额外解码为二进制数据后才能使用,增加了处理步骤。
兼容性影响:
在某些低版本浏览器或特殊环境中,Base64 可能会遇到解码问题,而 Blob 的支持更广泛。
4. 内存占用
Blob:Blob 是二进制数据,存储和渲染时占用的内存较少。
Base64:Base64 是文本格式,存储和渲染时会占用更多内存。
兼容性影响:
对于内存有限的设备(如移动端),Base64 可能导致内存不足或性能下降,而 Blob 更节省资源。
5. URL 使用
Blob:可以通过
URL.createObjectURL(blob)生成一个临时 URL,直接用于图片渲染或文件下载。Base64:Base64 数据可以直接嵌入到
src属性中(如data:image/png;base64,...),但会导致 HTML 或 CSS 文件体积增大。兼容性影响:
Base64 数据嵌入 HTML 或 CSS 中可能会导致文件过大,影响加载速度,而 Blob 的临时 URL 更灵活且高效。
6. 安全性
Blob:Blob 是二进制数据,不易被直接修改或注入恶意代码。
Base64:Base64 是文本格式,容易被篡改或注入恶意内容。
兼容性影响:
在安全性要求较高的场景中,Blob 更可靠。
7. API 支持
Blob:现代浏览器广泛支持 Blob,并且可以与
File、FileReader、FormData等 API 无缝配合。Base64:虽然 Base64 也被广泛支持,但在某些 API 中需要额外处理(如解码)。
兼容性影响:
Blob 更适合与现代 Web API 结合使用,兼容性更好。
总结
| 特性 | Blob 格式 | Base64 格式 |
|---|---|---|
| 文件大小 | 原始大小,无额外开销 | 增加约 33% 的体积 |
| 传输效率 | 高效,适合网络传输 | 较低,需要编码和解码 |
| 内存占用 | 较少 | 较多 |
| 浏览器支持 | 广泛支持,原生二进制格式 | 需要额外解码 |
| URL 使用 | 生成临时 URL,灵活高效 | 直接嵌入 HTML/CSS,可能导致文件过大 |
| 安全性 | 较高,不易篡改 | 较低,易被篡改 |
| API 支持 | 与现代 API 无缝配合 | 需要额外处理 |
因此,Blob 格式的图片在文件大小、传输效率、内存占用、浏览器支持和安全性等方面表现更好,兼容性更强,尤其是在处理大文件或高性能要求的场景中。而 Base64 格式更适合用于小图片或需要直接嵌入文本的场景(如邮件或简单的数据存储)。
相关文章:
WEB前端将指定DOM生成图片并下载最佳实践(html2canvas)
前言: html2canvas 是一个 JavaScript 库,其主要作用是将 HTML 元素或其部分内容渲染为 Canvas 图像。通过它,开发者可以将网页中的任意 DOM 元素(包括文本、图片、样式等)转换为图片格式(如 PNG 或 JPEG&…...
掌握.NET Core后端发布流程,如何部署后端应用?
无论你是刚接触.NET Core的新手还是已有经验的开发者,在这篇文章中你将会学习到一系列实用的发布技巧与最佳实践,帮助你高效顺利地将.NET Core后端应用部署到生产环境中 目录 程序发布操作 Docker容器注册表 文件夹发布 导入配置文件 网站运行操作 …...
深度学习学习笔记(34周)
目录 摘要 Abstracts 简介 Hourglass Module(Hourglass 模块) 网络结构 Intermediate Supervision(中间监督) 训练过程细节 评测结果 摘要 本周阅读了《Stacked Hourglass Networks for Human Pose Estimation》…...
C++ 设计模式-备忘录模式
游戏存档实现,包括撤销/重做、持久化存储、版本控制和内存管理 #include <iostream> #include <memory> #include <deque> #include <stack> #include <chrono> #include <fstream> #include <sstream> #include <ct…...
TOGAF之架构标准规范-信息系统架构 | 应用架构
TOGAF是工业级的企业架构标准规范,信息系统架构阶段是由数据架构阶段以及应用架构阶段构成,本文主要描述信息系统架构阶段中的应用架构阶段。 如上所示,信息系统架构(Information Systems Architectures)在TOGAF标准规…...
第一届网谷杯
统计四场的所有题目(共计12题,四场比赛一共上了21题【包括换题】) 随便记记,以免老题复用(已经复用了) Web 文件包含 1 伪协议 http://120.202.175.143:8011/?cphp://filter/convert.base64-encode/reso…...
Linux(ubuntu) GPU CUDA 构建Docker镜像
一、创建Dockerfile FROM ubuntu:20.04#非交互式,以快速运行自动化任务或脚本,无需图形界面 ENV DEBIAN_FRONTENDnoninteractive# 安装基础工具 RUN apt-get update && apt-get install -y \curl \wget \git \build-essential \software-proper…...
mysql -DQL语句和DCL语句
DQL 数据查询语言(Data Query Language,DQL)是数据库操作语言的重要组成部分,主要用于从数据库中检索数据,核心关键字为SELECT。以下从语法结构、常见操作及示例等方面详细介绍: 语法结构 DQL 的标准语法…...
掌握 ElasticSearch 组合查询:Bool Query 详解与实践
掌握 ElasticSearch 组合查询:Bool Query 详解与实践 一、引言 (Introduction)二、Bool 查询基础2.1 什么是 Bool 查询?2.2 Bool 查询的四种子句2.3 语法结构 三、Bool 查询的四种子句详解与示例3.1 must 子句3.2 filter 子句3.3 should 子句3.4 must_no…...
C++ 类和对象(友元、内部类、匿名对像)
目录 一、前言 二、正文 1.友元 1.1友元函数的使用 1.1.1外部友元函数可访问类的私有成员,友员函数仅仅是一种声明,他不是类的成员函数。 1.1.2一个函数可以是多个类的友元函数 2.友元类的使用 2.1什么是友元类 2.2 友元类的关系是单向的&#x…...
PostgreSQL 常用函数
PostgreSQL 常用函数 在数据库管理系统中,函数是执行特定任务的基本构建块。PostgreSQL 是一个功能强大的开源关系数据库管理系统,提供了丰富的内置函数,这些函数极大地增强了数据库操作的能力。以下是一些在 PostgreSQL 中常用的函数&#…...
掌握 ElasticSearch 四种match查询的原理与应用
文章目录 一、引言 (Introduction)二、准备工作:创建索引和添加示例数据三、match 查询四、match_all 查询五、multi_match 查询六、match_phrase 查询七、总结 (Conclusion) 一、引言 (Introduction) 在信息爆炸的时代,快速准确地找到所需信息至关重要…...
解决:Conda虚拟环境中未设置CUDA_HOME的问题
背景:我是Ubuntu22.04系统,最近在复现FoundationPose算法,按照README构建部署环境时,有一步一直卡住,看了下是未找到CUDA_HOME这个环境变量。 网上搜了下这个错误,需要设置CUDA_HOME的环境变量路径&#x…...
easyexcel和poi同时存在版本问题,使用easyexcel导出excel设置日期格式
这两天在使用easyexcel导出excel的时候日期格式全都是字符串导致导出的excel列无法筛选 后来调整了一下终于弄好了,看一下最终效果 这里涉及到easyexcel和poi版本冲突的问题,一直没搞定,最后狠下心来把所有的都升级到了最新版,然…...
HarmonyOS 开发套件 介绍——下篇
HarmonyOS 开发套件 介绍——下篇 在HarmonyOS的生态中,开发套件作为支撑整个系统发展的基石,为开发者提供了丰富而强大的工具和服务。本文将深入继续介绍HarmonyOS SDK、ArkCompiler、DevEco Testing、AppGallery等核心组件,帮助开发者全面掌…...
关于order by的sql注入实验
实验描述 本实验基于sqli-lab的第46关进行测试 本关的sql 语句为$sql "SELECT * FROM users ORDER BY $id" 利用sort进行sql注入,我们可以利用报错注入,延时注入来爆出数据 1.报错注入 1.手工测试 爆出数据库 ?sort(extractvalue(1, c…...
Transformers快速入门-学习笔记
一、自然语言处理 NLP 是借助计算机技术研究人类语言的科学自然语言处理发展史 一、不懂语法怎么理解语言 依靠语言学家人工总结文法规则 Chomsky Formal Languages 难点:上下文有关文法 规则增多,存在矛盾 二、只要看得足够多,就能处理语言…...
luci界面开发中的MVC架构——LuCI介绍(二)
想要给openwrt开发应用,虽然直接可执行程序也可以运行,但是没有UI会很不方便,想要开发UI就要用openwrt的那一套,自然就是LuCI,LuCI又用了一套MVC框架,今天就讲讲这是个什么东西。 OpenWrt LuCI 界面开发中…...
第1章大型互联网公司的基础架构——1.10 其他NoSQL数据库
这里我们简单介绍一下其他常见的NoSQL数据库及其适用的场景,其中部分数据库会在后续服务设计章节中正式使用时再做详细介绍。 1.10.1 文档数据库 文档数据库的典型代表是MongoDB和CouchDB。**文档数据库普遍采用JSON格式来存储数据,而不是采用僵硬的行…...
DeepSeek+Kimi生成高质量PPT
DeepSeek与Kimi生成PPT全流程解析 一、工具分工原理 DeepSeek核心作用:生成结构化PPT大纲(擅长逻辑构建与内容优化)Kimi核心作用:将文本转换为视觉化PPT(提供模板库与排版引擎) 二、操作步骤详解 1. 通…...
Vue记事本应用实现教程
文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展:显示创建时间8. 功能扩展:记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...
uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖
在前面的练习中,每个页面需要使用ref,onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入,需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...
visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...
Keil 中设置 STM32 Flash 和 RAM 地址详解
文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...
Java 加密常用的各种算法及其选择
在数字化时代,数据安全至关重要,Java 作为广泛应用的编程语言,提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景,有助于开发者在不同的业务需求中做出正确的选择。 一、对称加密算法…...
3403. 从盒子中找出字典序最大的字符串 I
3403. 从盒子中找出字典序最大的字符串 I 题目链接:3403. 从盒子中找出字典序最大的字符串 I 代码如下: class Solution { public:string answerString(string word, int numFriends) {if (numFriends 1) {return word;}string res;for (int i 0;i &…...
MySQL用户和授权
开放MySQL白名单 可以通过iptables-save命令确认对应客户端ip是否可以访问MySQL服务: test: # iptables-save | grep 3306 -A mp_srv_whitelist -s 172.16.14.102/32 -p tcp -m tcp --dport 3306 -j ACCEPT -A mp_srv_whitelist -s 172.16.4.16/32 -p tcp -m tcp -…...
【生成模型】视频生成论文调研
工作清单 上游应用方向:控制、速度、时长、高动态、多主体驱动 类型工作基础模型WAN / WAN-VACE / HunyuanVideo控制条件轨迹控制ATI~镜头控制ReCamMaster~多主体驱动Phantom~音频驱动Let Them Talk: Audio-Driven Multi-Person Conversational Video Generation速…...
A2A JS SDK 完整教程:快速入门指南
目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库ÿ…...
Golang——9、反射和文件操作
反射和文件操作 1、反射1.1、reflect.TypeOf()获取任意值的类型对象1.2、reflect.ValueOf()1.3、结构体反射 2、文件操作2.1、os.Open()打开文件2.2、方式一:使用Read()读取文件2.3、方式二:bufio读取文件2.4、方式三:os.ReadFile读取2.5、写…...
