uniapp引入插件市场echarts图表(l-echart)实现小程序端图表,并修改源码实现watch监听option

使用的uniapp插件:l-echart

https://ext.dcloud.net.cn/plugin?id=4899

注意事项

1.因为小程序有主包分包大小限制,并且uni_modules中的包也会算在主包体积中,而我项目中的图表是在分包中使用的,所以我移动uni_modules中的l-echart图表组件到分包目录组件文件夹中
2.精简echarts.min.js体积,因为需求中只需要柱图和饼图,所以我去https://echarts.apache.org/zh/builder.html下载指定的 echarts 组件压缩包,然后替换l-echart中的echarts.min.js文件,只需要500kb左右大小

页面中使用的用法
<template><view class="charts-box"><l-echart ref="chart" ="init" class="charts-box"></l-echart></view>
</template><script>
import LEchart from "@/package-pc/pages/components/lime-echart/components/l-echart/l-echart.vue";
import * as echarts from "@/package-pc/pages/components/lime-echart/static/echarts.min.js";
import option from "@/package-pc/pages/monthreport/option";
export default {components: {LEchart,},data() {return {option: option,};},// 使用组件的finished事件里调用methods: {async init() {const chart = await this.$refs.chart.init(echarts);chart.setOption(this.option);},},
};
</script><style scoped>
/* 请根据实际需求修改父元素尺寸,组件自动识别宽高 */
.charts-box {width: 100%;height: 600px;
}
</style>
修改l-echart源码,简化组件用法:

1.组件中直接引入echarts.min.js
2.props增加option传参
3.watch中监听option传参
4.mounted中直接执行init方法初始化图表
5.init方法中调用setOption方法
6.加入uni.onWindowResize方法监听宽高变化,然后调用原本就实现的resize方法

import * as echarts from "@/package-pc/pages/components/lime-echart/static/echarts.min.js";
export default {name: "lime-echart",props: {...option: {type: Object,},},watch: {option: {handler() {this.setOption(this.option);},deep: true,},},mounted() {this.$nextTick(async () => {this.$emit("finished");await this.init();});},methods:{...async init(...args) {// #ifndef APP-NVUE// if (arguments && arguments.length < 1) {//   console.error(//     "缺少参数:init(echarts, theme?:string, opts?: object, callback?: function)"//   );//   return;// }// #endif...this.chart = echarts.init(config.canvas,theme,Object.assign({}, config, opts));this.chart.setOption(this.option ?? {});uni.onWindowResize(() => {this.resize();});...},}
修改后的页面用法

直接传参option给组件,请求接口后修改option即可

<template><view class="charts-box"><l-echart :option="option1" class="charts-box"></l-echart></view>
</template><script>
import LEchart from "@/package-pc/pages/components/lime-echart/components/l-echart/l-echart.vue";
import option from "@/package-pc/pages/monthreport/option";
export default {components: {LEchart,},data() {return {option: option,};},// 修改option即可methods: {async setText() {this.option.title.text = "test"},},
};
</script><style scoped>
/* 请根据实际需求修改父元素尺寸,组件自动识别宽高 */
.charts-box {width: 100%;height: 600px;
}
</style>

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

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

相关文章

Linux简单部署Yearning并结合内网穿透工具发布至公网可访问

目录 前言 1. Linux 部署Yearning 2. 本地访问Yearning 3. Linux 安装cpolar 4. 配置Yearning公网访问地址 5. 公网远程访问Yearning管理界面 6. 固定Yearning公网地址 前言 Yearning 简单, 高效的MYSQL 审计平台 一款MYSQL SQL语句/查询审计工具&#xff0c;为DBA与开发…

Vue混淆与还原

Vue混淆与还原 引言 Vue是一种流行的JavaScript框架&#xff0c;用于构建用户界面。它简单易用且功能强大&#xff0c;备受开发者喜爱。然而&#xff0c;在传输和存储过程中&#xff0c;我们需要保护Vue代码的安全性。混淆是一种有效的保护措施&#xff0c;可以加密和压缩代码…

Course2-Week1-神经网络

Course2-Week1-神经网络 文章目录 Course2-Week1-神经网络1. 神经网络概述1.1 欢迎来到Course21.2 神经元和大脑1.3 引入神经网络-需求预测1.4 神经网络的其他示例-图像感知 2. 神经网络的数学表达式2.1 单层的神经网络-需求预测2.3 前向传播的神经网络-手写数字识别 3. Tensor…

学生护眼台灯怎么样选择?适合考研的护眼台灯推荐

很多家长都是为了孩子的视力健康而置换的护眼台灯&#xff0c;但是有一部分孩子用了之后反而会和家长说出现眼睛不太舒服&#xff0c;甚至近视加深的情况。而引发这种情况的大多数为产品不达标或非专业台灯&#xff0c;因为专业护眼台灯是真实能够保护眼睛的。 所以很多人都对护…

文件上传漏洞(带实例)

漏洞介绍&#xff1a; 现代互联网的Web应用程序中&#xff0c;上传文件是一种常见的功能&#xff0c;因为它有助于提高业务效率&#xff0c;如企业的OA系统&#xff0c;允许用户上传图片&#xff0c;视频&#xff0c;头像和许多其他类型的文件。然而向用户提供的功能越多&#…

【Polar靶场WEB签到】

题目&#xff1a; <?phperror_reporting(0);$file $_GET[file];if(!isset($file))$file 1;$file str_replace(../, , $file);include_once($file.".php");highlight_file(__FILE__); ?>解答&#xff1a;1、进入index页面&#xff0c;说让你加弟弟&#x…

JeecgBoot 框架升级至 Spring Boot3 的实战步骤

JeecgBoot 框架升级 Spring Boot 3.1.5 步骤 JEECG官方推出SpringBoot3分支&#xff1a;https://github.com/jeecgboot/jeecg-boot/tree/springboot3 本次更新由于属于破坏式更新&#xff0c;有几个生态内的组件&#xff0c;无法进行找到平替或无法升级&#xff0c;目前尚不完…

ArcGIS平滑处理栅格数据

一、实验背景 基于栅格数据的空间分析&#xff0c;常常需要根据特定的分析场景对栅格数据进行处理&#xff0c;如栅格数据的噪声处理。噪声是属性值具有突跃特征的像元位置&#xff0c;直接对带有噪声的栅格数据进行分析会对结果造成较大的影响。而降噪的主要方法之一是平滑&a…

会议剪影 | “聚势合力 共创高峰”2023思腾合力成都客户答谢会圆满结束

2023年11月29日至12月1日&#xff0c;以“聚势合力 共创高峰”为主题的思腾合力成都答谢会&#xff0c;在成都都江堰皇冠假日酒店盛大举行&#xff0c;来自各地的客户齐聚于此&#xff0c;共同见证思腾合力的成长与突破&#xff0c;展望未来的合作与发展。 思腾合力总经理王伟热…

sql30(Leetcode1731每位经理的下属员工数量)

代码&#xff1a; # Write your MySQL query statement below select view.employee_id,e.name,view.reports_count,view.average_age from(select reports_to as employee_id,count(employee_id) as reports_count,round(avg(age),0) as average_agefrom Employeesgroup by …

2024面试必备的MySQL基础初级面试文集。

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

16进制字符串转字符串

一、浏览器上 function hexToUtf8(hexString) {const hexArray hexString.match(/.{1,2}/g) || [];const uint8Array new Uint8Array(hexArray.map(hex > parseInt(hex, 16)));const textDecoder new TextDecoder(GB2312); //可以切换字符编码return textDecoder.decode…

Opencv获取当前视频长宽、总帧数、fps

Opencv提供了类似java中静态变量的参数&#xff0c;可以通过get(参数)获取当前视频的信息&#xff0c;参数类别还是挺多的&#xff0c;按照需求查手册或源码即可。 源码参数举例 获取视频帧的长宽 import cv2 if __name__ __main__:mp4_path xhx_utils/images/demo.mp4video…

【hacker送书第9期】算法训练营(入门篇)

第9期图书推荐 内容简介作者简介精彩书评图书目录概述参与方式 内容简介 本书以海量图解的形式&#xff0c;详细讲解常用的数据结构与算法&#xff0c;又融入大量的竞赛实例和解题技巧。通过对本书的学习&#xff0c;读者可掌握12种初级数据结构、15种常用STL函数、10种二叉树和…

C程序的内存布局分析

C 程序的典型内存由以下部分组成&#xff1a; 文本段&#xff08;text&#xff09;初始化数据段 &#xff08;data&#xff09;未初始化数据段&#xff08;bss&#xff09;堆 &#xff08;heap&#xff09;栈&#xff08;stack&#xff09; 典型内存布局&#xff1a; 1.文本段…

极智芯 | 解读国产AI算力 沐曦产品矩阵

欢迎关注我的公众号 [极智视界],获取我的更多经验分享 大家好,我是极智视界,本文分享一下 解读国产AI算力 沐曦产品矩阵。 2020 年是国产 AI 芯片创业爆发的一年,GPU 市场竞争激烈,外有英伟达、AMD、高通等巨头,内有天数智芯、璧仞科技、摩尔线程等新锐,再加上华为昇腾…

网页产品经理常用的ChatGPT通用提示词模板

产品策略&#xff1a;请帮助我制定一个网页产品的产品策略。 市场调研&#xff1a;如何进行网页产品的市场调研&#xff1f; 用户需求&#xff1a;如何确定网页产品的用户需求&#xff1f; 产品设计&#xff1a;如何设计一个优秀的网页产品&#xff1f; 用户体验&#xff1…

tomcat 有哪几种Connector 运行模式(优化)?

Tomcat 的 Connector 用于处理 HTTP 请求&#xff0c;它决定了 Tomcat 如何与 Web 应用程序进行交互。在 Tomcat 中&#xff0c;Connector 有多种类型&#xff0c;并且每种类型都有不同的运行模式和优化选项。以下是一些常见的 Connector 类型及其运行模式&#xff1a; HTTP/1…

Java 控制台命令导入本地jar包到maven本地库中

1、新建POM文件&#xff0c;在maven库路径下创建POM文件 注意&#xff1a;这个路径需要与第2点导入命令中的grouoId、artifactId和version写法对应 Path&#xff1a;D:\RomanData\repository\com\sae\mail\1.0.0\mail-1.0.0.pom <?xml version"1.0" encoding&q…

基于web的ssm邮票鉴赏系统源码和论文

网络的广泛应用给生活带来了十分的便利。所以把邮票鉴赏管理与现在网络相结合&#xff0c;利用java技术建设邮票鉴赏系统&#xff0c;实现邮票鉴赏的信息化。则对于进一步提高邮票鉴赏管理发展&#xff0c;丰富邮票鉴赏管理经验能起到不少的促进作用。 邮票鉴赏系统能够通过互…