当前位置: 首页 > wzjs >正文

上海装饰公司排名百强网站优化提升排名

上海装饰公司排名百强,网站优化提升排名,用asp做宠物网站页面,中国空间站首次太空授课目录 背景介绍 想要实现样式 代码说明 关键点解析 (1) 默认隐藏“日常巡检” (2) 图例点击事件 (3) 动态更新图表 (4) 数据结构 运行结果 (1) 默认状态 (2) 点击图例 扩展功能 (1) 自定义初始隐藏多个图例 (2) 添加动画效果 (3) 响应式布局 总结 参考 背景介绍…

目录

背景介绍

想要实现样式

代码说明

关键点解析

(1) 默认隐藏“日常巡检”

(2) 图例点击事件

(3) 动态更新图表

(4) 数据结构

运行结果

(1) 默认状态

(2) 点击图例

扩展功能

(1) 自定义初始隐藏多个图例

(2) 添加动画效果

(3) 响应式布局

总结

参考


背景介绍

在最近一个大屏中,有一个需求,想默认隐藏“日常巡检”图例,在用户点击图例的时候显示或隐藏对应的图例;

想要实现样式

在大屏中,产品想让默认不显示“日常巡检”,鼠标移入时tooltip中不显示“日常巡检”的

再点击图例“日常巡检”,显示“日常巡检”的值,tooltip中显示“日常巡检”的

代码说明

在查找了echart官网配置后

了解到可以通过配置 legendseriesshow 属性来实现默认隐藏某些图例(如“日常巡检”),并在用户点击图例时显示或隐藏对应的数据系列。以下是完整的实现代码和详细解析。

<template><div ref="chart" style="width: 100%; height: 500px;"></div>
</template><script>
import * as echarts from 'echarts';
import { onMounted, ref } from 'vue';export default {setup() {const chart = ref(null); // 用于挂载图表的 DOM 元素const initChart = () => {// 初始化 ECharts 实例const myChart = echarts.init(chart.value);// 配置项const option = {title: {text: '折线图',left: 'center',},tooltip: {trigger: 'axis',},legend: {data: ['维修养护', '日常巡检', '应急响应'], // 图例名称},xAxis: {type: 'category',data: ['00:00', '04:00', '08:00', '12:00', '16:00', '20:00'], // 时间轴数据},yAxis: {type: 'value',},series: [{name: '维修养护',type: 'line',data: [1.2, 1.5, 1.3, 1.7, 1.6, 1.8], },{name: '日常巡检',type: 'line',data: [0.5, 0.6, 0.7, 0.8, 0.9, 1.0], show: false, // 默认不显示},{name: '应急响应',type: 'line',data: [10, 15, 20, 25, 30, 35], },],};// 设置初始配置myChart.setOption(option);// 监听图例点击事件myChart.on('legendselectchanged', (event) => {const selected = event.selected; // 获取当前图例选中状态const newOption = {series: option.series.map((serie) => {return {...serie,show: selected[serie.name], // 根据图例选中状态动态设置 show 属性};}),};myChart.setOption(newOption); // 更新图表配置});};// 在组件挂载时初始化图表onMounted(() => {initChart();});return {chart,};},
};
</script><style scoped>
.chart-container {width: 100%;height: 500px;
}
</style>

关键点解析

(1) 默认隐藏“日常巡检”
  • 在 series 配置中,为“日常巡检”数据系列添加 show: false,使其默认不显示。
  • 注意:ECharts 并没有原生支持 show 属性,因此需要通过监听图例点击事件动态控制显示/隐藏。
(2) 图例点击事件
  • 使用 myChart.on('legendselectchanged', callback) 监听图例点击事件。
  • event.selected 是一个对象,记录了每个图例的选中状态(true 表示选中,false 表示未选中)。
  • 根据 event.selected 动态更新 series 的 show 属性,并调用 setOption 刷新图表。
(3) 动态更新图表
  • 在 legendselectchanged 回调中,通过 option.series.map() 遍历所有数据系列,并根据 selected 状态动态设置 show 属性。
  • 最后调用 myChart.setOption(newOption) 更新图表。
(4) 数据结构
  • xAxis.data 定义了时间轴数据。
  • series 定义了多个数据系列(如'维修养护', '日常巡检', '应急响应')。
  • 每个数据系列的 data 是对应的数值数组。

运行结果

(1) 默认状态
  • 图表中默认显示“维修养护”和“应急响应”的线或柱,“日常巡检”的折线被隐藏。
(2) 点击图例
  • 点击“日常巡检”图例时,显示“日常巡检”的折线。
  • 再次点击“日常巡检”图例时,隐藏“日常巡检”的折线。

扩展功能

(1) 自定义初始隐藏多个图例

如果需要默认隐藏多个图例,可以在 series 中为对应的系列添加 show: false。例如:

series: [{name: '日常养护',type: 'line',data: [1.2, 1.5, 1.3, 1.7, 1.6, 1.8],},{name: '维修养护',type: 'line',data: [0.5, 0.6, 0.7, 0.8, 0.9, 1.0],show: false, // 默认隐藏},{name: '应急响应',type: 'line',data: [10, 15, 20, 25, 30, 35],show: false, // 默认隐藏},
],
(2) 添加动画效果

可以通过 animation 属性为折线图添加动画效果。例如:

series: [{name: '日常养护',type: 'line',data: [1.2, 1.5, 1.3, 1.7, 1.6, 1.8],animation: true, // 开启动画},
],
(3) 响应式布局

确保图表容器的宽度和高度是响应式的,可以结合 CSS 或 JavaScript 动态调整图表大小。例如:

window.addEventListener('resize', () => {myChart.resize();
});

总结

通过上述代码,你可以在 Vue 中实现以下功能:

  1. 默认隐藏某些图例(如“日常养护”)。
  2. 点击图例时动态显示或隐藏对应的数据系列。
  3. 动态更新图表配置,提升用户体验。

这种方法适用于需要灵活控制图例显示/隐藏的场景,例如多维度数据分析、实时监控等。

参考

echarts api:Documentation - Apache ECharts

http://www.dtcms.com/wzjs/421557.html

相关文章:

  • 网站制作优势网站推广线上推广
  • 400电话单页网站seo云优化软件
  • 江苏网站seo平台sem代运营
  • 北京网络电视台seo在线优化技术
  • 排名好的网站开发深圳今天重大事件新闻
  • 网页产品设计郑州seo网站管理
  • 电子商务网站建设 试卷长沙网站定制公司
  • 做网站vs2012能不能做seo快速优化文章排名
  • 个人网站建设设计网络营销的优缺点
  • 哪些网站可以做淘宝客热搜榜百度
  • 网站 手机兼容百度竞价关键词质量度怎么提升
  • 如何制作网站主页淮南网站seo
  • wordpress模板dux主题seo网站优化技术
  • 微商营销宝最新版百度系优化
  • 广州网站制作工作室如何做电商新手入门
  • 做网站需要视频衔接怎么做引流推广是什么意思
  • 委托代办网站建设需要注意什么发表文章的平台有哪些
  • 做网站运营很累吧百度推广如何代理加盟
  • 长沙响应式网站建设多少关键词排名优化软件
  • 建个网站的流程网站策划是什么
  • 北京赵公口网站建设宣传广告
  • 做直播网站要多少钱在线外链发布工具
  • 茌平企业做网站推广seo推广知识
  • 企业网站找私人做什提高工作效率的句子
  • b2c网站怎么推广seo搜索引擎优化排名哪家更专业
  • 深圳市网站建设公司千锋培训学费多少钱
  • 温州高端网站建设公司哪家好推广app接单网
  • 重庆微信网站建设报价网站建立具体步骤是
  • 仙游县网站建设新闻头条今日要闻最新
  • 苏州营销型网站制作网站设计公司网站制作