zoukankan      html  css  js  c++  java
  • echarts 折线图(移动端)X轴显示不全

    主要原因

    X轴文字太多,需要文字倾斜角度,换行以及省略

    X轴文字倾斜角度,换行

    interval

    坐标轴刻度标签的显示间隔(在类目轴中有效哦),默认会采用标签不重叠的方式显示标签(也就是默认会将部分文字显示不全)可以设置为0强制显示所有标签,如果设置为1,表示隔一个标签显示一个标签,如果为3,表示隔3个标签显示一个标签,以此类推

    rotate

    标签倾斜的角度,在类目轴的类目标签显示不全时可以通过旋转防止标签重叠(官方这样说的)旋转的角度是-90到90度

    xAxis:{
      axisLabel:{
        interval: 0,//X轴信息全部展示
        rotate: -60,//60 标签倾斜的角度
      }
    }
    

    依旧受到遮挡

    这个名称x轴的文字如果太长会受到遮挡,还是显示不全,这个时候可以用grid属性解决

    grid: {
      left: '10%',
      bottom:'35%'
    },
    

    需求(中文显示两行,文字过多显示省略号;长日期显示一行,过多显示省略号)

    formatter

    axisLabel中使用formatter回调,formatter有两个参数,使用方法是这样的formatter:function(value,index){} ,value是类目(测试医院A,人民医院),index 是类目索引。

    xAxis:{
      axisLabel:{
         formatter:function(value){
            let ret = ""; //拼接加
    返回的类目项
            let maxLength = 8; //每项显示文字个数
            if(value.length>2*maxLength){
              value = value.substring(0, 2*maxLength - 3) + "...";
            }
            let valLength = value.length; //X轴类目项的文字个数
            let rowN = Math.ceil(valLength / maxLength); //类目项需要换行的行数
            if(/.*[/u4e00-/u9fa5]+.*$/.test(value)){//判断是否有中文
              if(rowN > 1){
                for (let i = 0; i < rowN; i++) {
                    let temp = "";//每次截取的字符串
                    let start = i * maxLength;//开始截取的位置
                    let end = start + maxLength;//结束截取的位置
                    //这里也可以加一个是否是最后一行的判断,但是不加也没有影响,那就不加吧
                    temp = value.substring(start, end) + "
    ";
                    ret += temp; //凭借最终的字符串
                }
                return ret
              }else{
                return value 
              }
            }else{
              return value
            }
         }
      }
    }
    

    总结

    整体代码

    op1:{
      grid: {
        left: '10%',
        bottom:'35%'
      },
      xAxis:{
        axisLabel:{
           textStyle:{
              color: "#444",
              fontSize: 8,
              lineHeight: 9
           },
           formatter:function(value){
              let ret = ""; //拼接加
    返回的类目项
              let maxLength = 8; //每项显示文字个数
              if(value.length>2*maxLength){
                value = value.substring(0, 2*maxLength - 3) + "...";
              }
              let valLength = value.length; //X轴类目项的文字个数
              let rowN = Math.ceil(valLength / maxLength); //类目项需要换行的行数
              if(/.*[/u4e00-/u9fa5]+.*$/.test(value)){//判断是否有中文
                if(rowN > 1){
                  for (let i = 0; i < rowN; i++) {
                      let temp = "";//每次截取的字符串
                      let start = i * maxLength;//开始截取的位置
                      let end = start + maxLength;//结束截取的位置
                      //这里也可以加一个是否是最后一行的判断,但是不加也没有影响,那就不加吧
                      temp = value.substring(start, end) + "
    ";
                      ret += temp; //凭借最终的字符串
                  }
                  return ret
                }else{
                  return value 
                }
              }else{
                return value
              }
           }
        },
        interval: 0,//X轴信息全部展示
        rotate: -60,//60 标签倾斜的角度
      }
    }
    

    echarts 折线图(移动端)X轴显示不全

  • 相关阅读:
    img标签中的alt属性在IE6/7/8中的兼容问题
    fontsize可以解决img标签插入图片之间的缝隙
    BFC
    为什么 input 元素能用 width 属性
    <textarea>使用的时候发现的两个问题的总结
    c语言-概述
    C语言- while 语句
    C语言- for 语句
    C语言- if 语句
    C语言-编译运行程序
  • 原文地址:https://www.cnblogs.com/yihan123/p/13641159.html
Copyright © 2011-2022 走看看