Echarts图例legend选中select状态动态更新(踩坑)

今天计划实现一个小功能,但是却在细节上浪费了大量的时间,特此记录。

想要实现的功能是这样的,如下一个ECharts图,后台会一次性接收85条曲线的数据,但在初始化的时候只显示前7条曲线。
在这里插入图片描述
官方文档 给出了 legend. selected 这个属性,可以修改选中的图例。

legend: {
	selected: {
	    // 选中'系列1'
	    '系列1': true,
	    // 不选中'系列2'
	    '系列2': false
	}
}

有两种方式传递数据:

  1. 使用静态数据:'系列1': true
  2. 使用Object变量:{key:value}

要想实现动态更新,就只能用Object变量。我们继续:

//第一步
var selectedArray = {};//定义一个Object对象
var selectedArray = new Object();//此种方式也可以定义一个Object对象
//第二步
selectedArray ['No1'] = true;//添加数据,key='No1',value='true'
selectedArray ['No2'] = true;//添加数据,key='No2',value='true'
…………
//第三步
chart.setOption({
	……
	legend: {
		selected: selectedArray //绑定数据
	}
	……
})

完成! ~~

在第二步的时候,有一个大坑
selectedArray ['No1'] = true;
这句代码中的 true 如果写成了 'true'
就会造成ECharts无法识别传入数据的情况,并且还不会报错!
并且如果用console.log输出检查的话,也查不出任何错误!
足足浪费了四个小时,网上所有的方法都没找到……

剩下的功能还没做完,看来今天的熬夜了
害,继续加油吧!

ECharts中,可以通过配置选项来修改echarts图例legend的样式。具体样式的修改包括设置图例的位置、大小、间距、对齐方式、文本样式、背景色等。以下是一些常见的配置选项和样式修改实例: 1. 设置图例位置:可以通过设置legend的属性来控制图例的位置,如top、bottom、left、right等。比如设置图例位于顶部:legend: { top: 0 } 2. 调整图例大小和间距:可以使用itemWidth和itemHeight属性来调整图例项的大小,使用padding属性来调整图例的内边距。比如设置图例项高度为7px,内边距为10px:legend: { itemHeight: 7, padding: 10 } 3. 修改图例文本样式:可以使用textStyle属性来修改图例文字的样式,包括颜色、字体大小等。比如设置图例文字颜色为"#a1a1a1",字体大小为12px:legend: { textStyle: { color: '#a1a1a1', fontSize: 12 } } 4. 修改图例图标样式:可以使用icon属性来修改图例前面的图标形状,包括圆形、矩形、三角形等。比如设置图例图标形状为圆形:legend: { icon: 'circle' } 需要注意的是,图例data值必须与series里的name值对应,这样才能正确显示图例项。同时,ECharts还提供了其他的图例类型,如滚动图例、翻页图例等,可以根据实际需求选择合适的图例类型。 可以参考ECharts官方文档和示例来了解更多关于echarts图例legend的样式修改配置选项和使用示例。希望对你有所帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [echartslegend——图例样式的配置](https://blog.csdn.net/dyk11111/article/details/128406968)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [在echarts图例legend和坐标系grid实现左右布局实例](https://download.csdn.net/download/weixin_38725119/12852045)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值