旭东怪 2020-03-25 15:02 采纳率: 0%
浏览 986

echarts x轴分两级显示,并且第二级可以设置任意间隔

我在网上只找到x轴可以分两级显示,但是第二级平均分配间隔的方法
https://blog.csdn.net/u013270065/article/details/105073901/
我想要达到的效果如下图
图片说明

可以看看这个ECharts实例,实现了分两级显示并且第二级可以自定义间隔https://gallery.echartsjs.com/editor.html?c=xnUHWTiDTY
图片说明

  • 写回答

1条回答 默认 最新

  • lshen01 2023-03-17 04:14
    关注

    参考GPT和自己的思路:

    你好!针对你提出的问题,我可以给你以下回答:

    首先,在 ECharts 中实现 x 轴分两级显示,需要使用到 axis.label 里的 formatter 属性,并设置其返回一个数组。例如:

    xAxis: {
      type: 'category',
      data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'],
      axisLabel: {
        formatter: function (value, index) {
          let firstLevel = ['周一', '周二', '周三'];
          if (firstLevel.indexOf(value) > -1) {
            return value + '\n\n'; // 第一级数据换行
          } else {
            return value; // 第二级数据
          }
        }
      }
    },
    

    然后,在第二级数据中设置自定义间隔,也需要使用 axis.label 里的 formatter 属性,并使用 index 参数判断每个数据点位置。例如:

    xAxis: {
      type: 'category',
      data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'],
      axisLabel: {
        formatter: function (value, index) {
          let firstLevel = ['周一', '周二', '周三'];
          if (firstLevel.indexOf(value) > -1) {
            return value + '\n\n';
          } else {
            if (index % 2 === 0) {
              return value + '\n'; // 第二级间隔为 2
            } else {
              return value;
            }
          }
        }
      }
    },
    

    结合以上两段代码即可实现你要达到的效果。希望我的回答能够对你有所帮助!

    评论

报告相同问题?

悬赏问题

  • ¥30 Matlab打开默认名称带有/的光谱数据
  • ¥50 easyExcel模板 动态单元格合并列
  • ¥15 res.rows如何取值使用
  • ¥15 在odoo17开发环境中,怎么实现库存管理系统,或独立模块设计与AGV小车对接?开发方面应如何设计和开发?请详细解释MES或WMS在与AGV小车对接时需完成的设计和开发
  • ¥15 CSP算法实现EEG特征提取,哪一步错了?
  • ¥15 游戏盾如何溯源服务器真实ip?需要30个字。后面的字是凑数的
  • ¥15 vue3前端取消收藏的不会引用collectId
  • ¥15 delphi7 HMAC_SHA256方式加密
  • ¥15 关于#qt#的问题:我想实现qcustomplot完成坐标轴
  • ¥15 下列c语言代码为何输出了多余的空格