Echarts图表如何解决legend数量过大导致遮挡图表

开发Echarts图标时,经常遇到数据量过多引起的图例错乱,这个时候我们应该如何处理?

设置属性type: scroll


        legend: {
          type: 'scroll',
          orient: 'horizontal' // vertical
        }

效果如下:

horizontal效果:

 vertical效果:

 

 

  • 15
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您使用 ECharts 绘制的图表,同时在图表外层包裹了一个 div,可能会遇到图例(legend)的点击事件被外层 div 的事件遮挡的问题。这是因为 ECharts 的图例是绘制在 canvas 上的,而 canvas 是一个独立的 HTML 元素,其内部的事件处理与外层的 div 不同。 解决该问题的方法是,可以在外层 div 上添加一个鼠标事件,并通过判断事件的 target 是否为图例元素来决定是否处理该事件。示例代码如下: ```javascript var chartDom = document.getElementById('chart'); var myChart = echarts.init(chartDom); // 绑定图例的点击事件 myChart.on('legendselectchanged', function(params) { console.log(params); }); // 绑定外层 div 的鼠标事件 var divDom = document.getElementById('div'); divDom.addEventListener('click', function(event) { if (event.target.tagName === 'SPAN' && event.target.className.indexOf('ec-legend-item') >= 0) { // 如果点击的是图例元素,则处理该事件 event.stopPropagation(); myChart.dispatchAction({ type: 'legendToggleSelect', name: event.target.innerText }); } }); ``` 在上述代码,我们先通过 `myChart.on` 方法绑定了图例的点击事件,并在外层 div 上添加了一个事件监听器。当点击 div 时,我们可以通过 `event.target` 属性获取到实际被点击的元素,如果该元素是一个图例元素,则处理该事件,并通过 `myChart.dispatchAction` 方法来触发图例的展示或隐藏。同时,我们在处理事件时调用了 `event.stopPropagation` 方法来阻止事件冒泡到外层 div,从而避免了被遮挡的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值