图表操作——图表保存为图片+多个图表批量保存为压缩包——js技能提升

news2024/9/28 9:23:47

使用场景:
echarts图表:生成的柱状图/折线图/饼图等可以实现图表的导出,导出格式为一个图片。也可以支持多个图表同时导出为图片,以压缩包的形式下载下来。
在这里插入图片描述
下面介绍单个导出+批量导出的具体用法:

1.单个导出功能——以图片的形式

导出功能对应的是toolbox中的feature中的saveAsImage配置

toolbox: {
  show: true,
  right: '50',
  feature: {
    saveAsImage: { show: true, title: '保存为图片' }
  }
},

在这里插入图片描述
鼠标移入到【下载图标】后,可以显示title【保存为图片】

导出的图片名称即为title,上图中导出的图片名称即为【2024-08-29报废面积&报废率】

这是通过echarts内部方法实现的。

2.多个图片压缩后导出——以.zip的形式

需要通过jsZip来实现

解决步骤1:安装或者直接cdn引入jsZip

如果是插件安装,可以参考下面的链接:https://blog.csdn.net/sjajjajusja/article/details/135631109
在这里插入图片描述
cdn引入的话,因为我的项目是vue2项目,所以需要在public中的index.html中引入,并将jsZip.js放到static
在这里插入图片描述
在这里插入图片描述

解决步骤2:直接使用

下面的chart就是每一个的图表对象,也就是echarts.init创建出来的实例

let images = [];
let files = [];
 // 获取图表的Base64图片URL
const imageURL = chart.getDataURL({
  type: "png",
  pixelRatio: 2,
  backgroundColor: "#fff" // 可以根据需要设置背景色
});
// 将图片URL添加到数组中
images.push(imageURL);
files.push({
  name: `${titleArr[index]}.png`,
  content: this.base64ToBlob(imageURL)
});
this.downloadAsZip(files);

base64ToBlobbase64转为blob

//base64转blob
base64ToBlob(base64String) {
  // 移除URL的头部分,即 data:[<mediatype>][;base64],
  const parts = base64String.split(";base64,");
  // let contentType = contentType || parts[0].split(':')[1];
  let contentType = "image/png";
  let raw = window.atob(parts[1]);
  let rawLength = raw.length;
  // 创建一个Uint8Array类型的数组
  let uInt8Array = new Uint8Array(rawLength);
  // 将base64字符串中的每个字符转换成ASCII码(字符编码值)
  for (let i = 0; i < rawLength; ++i) {
    uInt8Array[i] = raw.charCodeAt(i);
  }
  // 使用上面得到的数组创建一个Blob对象
  return new Blob([uInt8Array], { type: contentType });
},

downloadAsZip函数如下:

//批量下载
downloadAsZip(files) {
  // 创建一个新的 JSZip 实例
  var zip = new JSZip();
  // 假设 files 是一个对象数组,每个对象包含 name 和 content(Blob或ArrayBuffer)
  files.forEach(function(file) {
    // 将文件添加到ZIP中
    zip.file(file.name, file.content, { binary: true });
  });
  // 生成ZIP文件并触发下载
  zip.generateAsync({ type: "blob" }).then(function(content) {
    // 创建一个指向该blob的URL
    var url = URL.createObjectURL(content);
    // 创建一个临时的a标签用于下载
    var a = document.createElement("a");
    document.body.appendChild(a);
    a.href = url;
    a.download = "责任工序分析.zip"; // 设置下载的文件名
    a.click();
    // 清理
    document.body.removeChild(a);
    window.URL.revokeObjectURL(url);
  });
},

上面就是批量导出多张图片存储到同一个压缩包的解决办法。

附录:如果想要在同一个dom元素中同时渲染柱状图+饼图,我的思路可能是创建两个并排的div子元素,分别去渲染。

但是在echarts中本身就支持多个图表的渲染,而且最后生成的结构是在同一个canvas中的。
在这里插入图片描述
解决方法就是:xAxisyAxis都作为一个对象数组,对象可以为空。series也是一个对象数组,每一个对象的xAxisIndexyAxisIndex都配置成对应的参数即可。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2088462.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用seamless-scroll-v3 实现无缝滚动,自动轮播平滑的滚动效果

安装&#xff1a;npm地址&#xff1a;https://www.npmjs.com/package/seamless-scroll-v3 yarn add seamless-scroll-v3# 或者使用 npm npm install seamless-scroll-v3# 或者使用 pnpm pnpm add seamless-scroll-v3 实现效果&#xff1a; template中的代码&#xff1a; <…

pmp证书为何会被骂?他真的就是个垃圾证书?

说是垃圾到不至于。 毕竟PMP证书今年被北京市列入急需紧缺专业人才人员名单&#xff01;同时可以在创新创业、社会保障、评价激励等方面得到优先支。 其次&#xff0c;证书&#xff0c;其内容可以夯实基础&#xff0c;理清一个项目从启动、执行到最后的收尾做ppt结案的整个流…

Leetcode Day13 双指针

392 判断一个str是不是另一个str的子序列(不用连续) class Solution:def isSubsequence(self, s: str, t: str) -> bool:if len(t) < len(s):return Falsel 0r 0while l < len(s):if s[l] t[r]:l 1r 1else:r 1if r > len(t):return l len(s)return True自己…

pdf.js如何支持base64的查看

1.pdf.js 作为一个查看在线阅读pdf的软件&#xff0c;常常被运用到前端开发中&#xff0c;但是如何让pdf支持base64的查看&#xff0c;这边就需要去进行修改一些代码了 这边我们就进行开发修改 首先去下载 https://mozilla.github.io/pdf.js/ 当然了&#xff0c;低版本的可以…

react-native框架下,集成字体并应用全局

一、存放字体文件 将自定义字体文件&#xff08;例如 .ttf 或 .otf 文件&#xff09;放入项目的 assets/fonts 目录中。如果没有这个目录&#xff0c;可以手动创建。 二、配置字体 在项目根目录下建一个文件&#xff1a;react-native.config.js&#xff0c;文件内容如下&…

数据类型6.2.1

c语言的变量要先定义&#xff0c;而且要用确定类型 c以后的语言 c jave更强调类型&#xff0c;对类型的检查更严格 JavaScript。Python。PHP不看重类型&#xff0c;甚至不需要事先定义 c语言的类型 整数 char &#xff0c; short&#xff0c; int…

【MATLAB源码-第257期】基于matlab的QPSK调制解调COSTAS环载波同步仿真,对比前后星座图,输出锁相环响应曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 QPSK&#xff08;Quadrature Phase Shift Keying&#xff0c;正交相移键控&#xff09;调制是一种常见的数字调制方式。它通过将比特数据映射到四个相位状态上来传输信息。每个符号代表两个比特的数据&#xff0c;因此与BPSK…

map和set(C++)

1.关联式容器 关联式容器&#xff1a;内部储存的是key或者k-v模型的数据 k-v模型&#xff1a;键值对 在STL中&#xff0c;键值对实际就是一个泛型的类&#xff0c;pair---->first(key) second(value) 分类&#xff1a;从底层数据结构上 红黑树结构 &#xff1a; …

单击视角复位按钮,即可看到整个地球【mars3d】

1.需要设置下初始默认视角&#xff0c;地图属性参数里面得 scene: { center: { 这个需要拿到一个参数&#xff0c;可以在示例里面随便抓一个想要的右键获取下 拿到之后再设置下&#xff0c;参考代码之后&#xff0c;就可以单击视角复位按钮&#xff0c;就回到可以看到整个地球…

19050 牛牛打气球

### 思路 1. **输入读取**&#xff1a; - 读取 n&#xff0c;a 和 b。 - 读取每个气球的坚韧度。 2. **计算最少释放次数**&#xff1a; - 使用二分查找来确定最少的释放次数。 - 每次释放武器时&#xff0c;选择一个气球多承受 a 点伤害&#xff0c;其他气球承受…

最简洁!四步完成C#——opencv环境配置

一.创建C#环境 二.右键点击管理NuGet 三.下载opencv环境 四.测试写入 using OpenCvSharp 不保存就完成了配置啦

Cycle inside Runner; building could produce unreliable results.

报错 Showing Recent Messages Cycle inside Runner; building could produce unreliable results. Cycle details: → Target Runner ○ That command depends on command in Target Runner: script phase “Thin Binary” ○ Target Runner has process command with outpu…

性能测试的基本概念

学习前的认知 我们在学习性能测试之前&#xff0c;需要有个新的认识&#xff1a;性能测试&#xff0c;不再是像功能测试一样单纯的找 Bug&#xff0c;而是去找性能指标 转变思维 在做功能测试、自动化测试的时候&#xff0c;我们基本都是依托界面进行测试&#xff0c;也称 GU…

人工智能训练师工作内容及职业发展路径

人工智能训练师&#xff08;AI Trainer&#xff09;是一种专业职位&#xff0c;主要负责训练和优化人工智能系统&#xff0c;尤其是机器学习模型。他们的工作涉及到以下几个方面&#xff1a; 1、数据准备&#xff1a;训练师需要收集、清洗和预处理数据&#xff0c;以确保数据的…

大语言模型训练数据常见的4种处理方法

大语言模型训练需要数万亿的各类型数据。如何构造海量“高质量”数据对于大语言模型的训练具有至关重要的作用。虽然&#xff0c;截止到2023 年9 月为止&#xff0c;还没有非常好的大模型的理论分析和解释&#xff0c;也缺乏对语言模型训练数据的严格说明和定义。但是&#xff…

rabbitmq发送的消息接收不到

1.消息被其他消费者消费 2.主要说的2这种情况&#xff0c;就是在延迟队列中&#xff0c;忘记给一个bean加注解导致日志报exchange not found. 这个报错&#xff0c;进而引发了bindings没有绑定。没有绑定的话&#xff0c;发送消息就会接收不到。

python-带空格的数字层三角形

[题目描述] 输入一个整数n&#xff0c;输出一个带空格的数字层状三角形。输入&#xff1a; 输入共一行&#xff0c;为一个整数n。输出&#xff1a; 输出一个带空格的数字层状三角形。样例输入1 8 样例输出1 11111111 2222222 333333 44444 5555 …

亦菲喊你来学机器学习(16) --K-means聚类算法

文章目录 K-means基本步骤优缺点构建模型 总结 K-means K-means 算法是一种广泛使用的聚类算法&#xff0c;旨在将数据集划分为 K 个簇&#xff0c;使得每个簇内的数据点尽可能相似&#xff0c;而不同簇之间的数据点尽可能不同。这个算法通过迭代的方式实现&#xff0c;每次迭…

三耐环保家族控股99.17%:分红6000多万再补流,董事长董秘一年3次被警示

《港湾商业观察》施子夫 王璐 持续冲刺北交所的杭州三耐环保科技股份有限公司&#xff08;以下简称&#xff0c;三耐环保&#xff09;日前收到第三轮审核问询函&#xff0c;其保荐机构为民生证券。 值得关注的是&#xff0c;第三轮审核问询函依旧围绕的问题是&#xff0c;进…

linux系统修改/etc/profile,修改错了,再打开乱码

执行vim /etc/profile&#xff0c; 在文件末尾增加两行配置&#xff0c;可能是$符号写错了&#xff0c;输入:x保存&#xff0c;提示输入密码(help cm),然后输入两次cm 执行source /etc/profile 提 示文件错误字段 执行cat profile结果如下&#xff1a; 这有没有办法还原啊…