关于前端:echarts-X轴数据过多如何显示完整

4次阅读

共计 2035 个字符,预计需要花费 6 分钟才能阅读完成。

x 轴文字太多显示不全

如图

解决办法 1

data:
myChart: {},
mounted:
this.myChart()
maChart:

 myChart() {
      const that = this
      // 基于筹备好的 dom,初始化 echarts 实例
      this.maChart = this.$echarts.init(document.getElementById('myChat'))
      // 绘制图表
      this.maChart.setOption({
        title: {text: '销售总量' + this.totalSellCount},
        tooltip: {show: true},
        xAxis: [{
          type: 'category',
          data: that.goodsName,
          axisLabel: {
            interval: 0,
            rotate:"45",
          }
        }],
        yAxis: [{type: 'value'}],
        grid: {// 直角坐标系内绘图网格
          show: true, // 是否显示直角坐标系网格。[default: false]
          // left:"20%",//grid 组件离容器左侧的间隔。// right:"30px",
          // borderColor:"",// 网格的边框色彩
          bottom: '35%' //
        },
        series: [{
          'name': '销量',
          'type': 'bar',
          'data': that.goodsCount,
          itemStyle: {
            normal: {
              label: {
                show: true, // 开启显示
                position: 'top', // 在上方显示
                textStyle: { // 数值款式
                  color: 'black',
                  fontSize: 16
                }
              }
            }
          }
        }]
      })
    },

援用
xAxis.axisLabel 属性
是坐标轴刻度标签的相干设置。官网文档查看 xAxis. axisLabel 配置项可看更多相干配置(yAxis 也一样有这个属性的)

xAxis.axisLabel.interval:
坐标轴刻度标签的显示距离,在类目轴中无效。
默认会采纳标签不重叠的策略距离显示标签。(默认文字太多不会全副显示进去)
能够设置成 0 强制显示所有标签。
设置 1 示意距离一个标签显示,2 示意距离两个标签 以此类推。

xAxis.axisLabel.rotate:
刻度标签旋转的角度,在类目轴的类指标签显示不下的时候能够通过旋转避免标签之间重叠。
旋转的角度从 -90 度到 90 度。

以上代码后果是这样的

文字数量少用以上这种形式还是能够的

解决办法 2

xAxis.axisLabel.formatter 形式
value 类目 index 索引

 axisLabel: {
            interval: 0,
            formatter:function(value) {return value.split("").join("\n");
            }
          }

后果如图

还是显示不齐全

改成两字换一行

 formatter: function(params) {
              var newParamsName = ''// 最终拼接成的字符串
              var paramsNameNumber = params.length// 理论标签的个数
              var provideNumber = 2// 每行能显示的字的个数
              var rowNumber = Math.ceil(paramsNameNumber / provideNumber)// 换行的话,须要显示几行,向上取整
              /**
               * 判断标签的个数是否大于规定的个数,如果大于,则进行换行解决 如果不大于,即等于或小于,就返回原标签
               */
              // 条件等同于 rowNumber>1
              if (paramsNameNumber > provideNumber) {
                /** 循环每一行,p 示意行 */
                for (var p = 0; p < rowNumber; p++) {
                  var tempStr = ''// 示意每一次截取的字符串
                  var start = p * provideNumber// 开始截取的地位
                  var end = start + provideNumber// 完结截取的地位
                  // 此处非凡解决最初一行的索引值
                  if (p === rowNumber - 1) {
                    // 最初一次不换行
                    tempStr = params.substring(start, paramsNameNumber)
                  } else {
                    // 每一次拼接字符串并换行
                    tempStr = params.substring(start, end) + '\n'
                  }
                  newParamsName += tempStr// 最终拼成的字符串
                }
              } else {
                // 将旧标签的值赋给新标签
                newParamsName = params
              }
              // 将最终的字符串返回
              return newParamsName
            }

后果

如果像这样有一半被挡住

能够调整直角坐标系内绘图网格
grid

grid: {// 直角坐标系内绘图网格
          // show: true, // 是否显示直角坐标系网格。[default: false]
          // left:"20%",//grid 组件离容器左侧的间隔。// right:"30px",
          // borderColor:"",// 网格的边框色彩
          bottom: '35%' // 离容器底部的间隔
        },
正文完
 0