监听ECharts图表dataZoom动态显示图表内容

需求 从接口获取到84条数据,要求一开始全显示的时候不显示inside的label,不管怎么滑动dataZoom的x轴,只要图表上的数据小于20条,就需要显示inside的label,否则不显示

1、第一时间肯定要监听dataZoom的事件,查阅文档之后发现能拿到滑动的start和end值

先拿到end和start的差值,差值根据echarts文档显示是百分比

javascript 复制代码
const zoom_cha = ref(0);
onMounted(() => {
  const myChart = echarts.init(document.getElementById("mydatazoom"));
  myChart.on("dataZoom", function (event) {
    const startValue = event.start;
    const endValue = event.end;
    zoom_cha.value = endValue - startValue;
  });
});

再根据差值大小判断数据条数,具体值是多少需要根据图表的宽度配置自行测试调整

监听差值实时判断是否显示inside的label值(在这里还可以动态的修改别的配置,数据源,tooltip等)

javascript 复制代码
const is_show_inside_label = ref(false);
watch(
  () => zoom_cha.value,
  () => {
    //暂定23%大概显示20条数据
    if (zoom_cha.value < 23) {
      is_show_inside_label.value = true;
    } else {
      is_show_inside_label.value = false;
    }
  }
);

最后找到对应要修改的配置项

javascript 复制代码
{
        name: "最低室温",
        type: "bar",
        data: minTempList,
        itemStyle: {
          color: "#0098FA",
        },
        barGap: "-100%",
        label: {
          // 控制显示不显示
          show: is_show_inside_label.value,
          position: "inside", 
          textStyle: {
            fontSize: chartItemSizeStore().labelFontSize,
            color: "#fff",
          },
        },
      },

大功告成,效果如下

相关推荐
AAA阿giao3 小时前
React 性能优化双子星:深入、全面解析 useMemo 与 useCallback
前端·javascript·react.js
不想秃头的程序员3 小时前
父传子全解析:从基础到实战,新手也能零踩坑
前端·vue.js·面试
大时光3 小时前
gsap 配置解读 --5
前端
Wect3 小时前
LeetCode 25. K个一组翻转链表:两种解法详解+避坑指南
前端·算法·typescript
shadowingszy3 小时前
【前端趋势调查系列】带你看看前端生态圈的技术趋势state-of-js 2025详细解读
前端·javascript·vue.js
@菜菜_达3 小时前
CSS是什么?
前端·css
2301_796512523 小时前
【精通篇】打造React Native鸿蒙跨平台开发高级复合组件库开发系列:Sticky 粘性布局(始终会固定在屏幕顶部)
javascript·react native·react.js·ecmascript·harmonyos
Amumu121383 小时前
CSS基础选择器
前端·css
南囝coding4 小时前
Claude Code 作者再次分享 Anthropic 内部团队使用技巧
前端·后端
colicode4 小时前
C#语音验证码API示例代码:快速实现.NET环境下的语音验证调用逻辑
前端·前端框架·语音识别