echarts问题

1、销毁

this.$echarts.dispose(document.getElementById('xxx'))

2、

let myChart = this.$echarts.init(document.getElementById('xxx'))
myChart.setOption(option)

 3、跟随缩放

        let myChart = this.$echarts.init(document.getElementById('data'));
        myChart.setOption(option);
        window.onresize = myChart.resize()

 4、设置tooltip

 tooltip: {
          trigger: 'axis',
          // position: 'inside',
          position: function (pos, params, dom, rect, size) {
            // 鼠标在左侧时 tooltip 显示到右侧,鼠标在右侧时 tooltip 显示到左侧。
            let obj = {top: 10}
            obj[['left', 'right'][+(pos[0] < size.viewSize[0] / 2)]] = 5
            return obj
          },
          // 始终显示在当前div里面
          confine: true
        },

 

雷达图按需求设置字体颜色

  let dataNormal = data.map((item) => { if (item >= 4) { return item} else { return } });
  let dataLow = data.map((item) => { if (item < 4) { return item} else { return } });
series: [
            {
              radius: '65%',
              center: ['0%', '50%'],
              type: 'radar',
              data: [
                {
                  value: data,
                }
              ],
              label: {
                // 显示数据
                show: false,
                // 文本位置
                position: 'top',
                distance: 7,
                // offset:[12,0]
              },
              // 设置区域边框和区域的颜色
              itemStyle: {
                normal: {
                  color: '#36b5e7',
                  lineStyle: {
                    color: '#36b5e7',
                  },
                },
              },
            },
            {
              radius: '65%',
              center: ['0%', '50%'],
              type: 'radar',
              //radarIndex: 1,
              data: [
                {
                  value: dataNormal,
                  //在拐点处显示数值
                  label: {
                    normal: {
                      show: true,
                      color: '#36b5e7'
                    }
                  }

                }
              ],
              // 设置区域边框和区域的颜色
              lineStyle: {
                width: 0,
                labelLine: {
                  show: false   //隐藏标示线
                }
              },
              itemStyle: {
                normal: {
                  color: '#36b5e7',
                  show: false
                }
              },
              silent: true,
              z: 2
            },
            {
              radius: '65%',
              center: ['0%', '50%'],
              type: 'radar',
              //radarIndex: 1,
              data: [
                {
                  value: dataLow,
                  //在拐点处显示数值
                  label: {
                    normal: {
                      show: true,
                      color: '#ff0000'
                    }
                  }

                }
              ],
              lineStyle: {
                width: 0,
                labelLine: {
                  show: false   //隐藏标示线
                }
              },
              silent: true,
              z: 3
            }
          ]

 X轴 多余省略号显示

xAxis: [
          {
            type: 'category',
            data: data.category,
            axisTick: {
              alignWithLabel: true
            },
            axisLabel: {
              show:true,
              interval: 0, //强制所有标签显示
              align:'center',
              // margin: 115, //标签向右移动 如果yAxis 跟 xAxis换了,这个margin应该调为0才能看见标签显示
              textStyle: {
                color: '#000',
              },
              formatter: function (params) {   //标签输出形式
                let index = 10;
                let newstr = '';
                for (let i = 0; i < params.length; i += index) {
                  let tmp = params.substring(i, i + index);
                  newstr += tmp + '\n';
                }
                if (newstr.length > 4) {
                  return newstr.substring(0, 4) + '...';
                } else {
                  return '\n' + newstr;
                }
              }
            }
          }
        ],

 柱状图点击范围

        // 范围点击
        myChart.getZr().on('click', params => {
          const pointInPixel = [params.offsetX, params.offsetY];
          if (myChart.containPixel('grid', pointInPixel)) {
            let xIndex = myChart.convertFromPixel({seriesIndex: 0}, [params.offsetX, params.offsetY])[0];
            let option = myChart.getOption()
            let val = option.xAxis[0].data[xIndex]
          }
        })

 点击Y轴事件

 let yIndex = myChart.convertFromPixel({ seriesIndex: 0 }, [params.offsetX, params.offsetY])[1]
              let option = myChart.getOption()
              let val = option.yAxis[1].data[yIndex]

 

        //将可以响应点击事件的范围内,鼠标样式设为pointer-----------------
        myChart.getZr().on('mousemove', function (params) {
          var pointInPixel = [params.offsetX, params.offsetY]
          if (myChart.containPixel('grid', pointInPixel)) {
            myChart.getZr().setCursorStyle('pointer')
          }
        })
        myChart.on('mouseout', function (params) {
          var pointInPixel = [params.offsetX, params.offsetY]
          if (!myChart.containPixel('grid', pointInPixel)) {
            myChart.getZr().setCursorStyle('default')
          }
        })

Y轴文本自定义颜色 

  yAxis: [
          {
            type: 'category',
            data: shopName.reverse(),
            axisLine: {show: false},
            axisTick: [
              {
                //坐标轴小标记
                show: false
              }
            ],
            axisLabel: {
              // color: "#858585",
              formatter: function (value, index) {
                if (value === '京东自营') {
                  return '' + value;
                } else {
                  return value
                }
              },
              textStyle: {
                // 设置分段颜色
                color: function (value) {
                  if (value === '京东自营') {
                    return '#ff0000'
                  } else {
                    return '#858585'
                  }
                }
              }
            }
          }
        ],

柱状图颜色

          series: [{
            name: '差评数',
            barWidth: 23,
            data: ldata,
            type: 'bar',
            itemStyle: {
              normal: {
                // 颜色
                // color: '#00a1e0',
                // 隔行变色
                // color: function (params) {
                //   //首先定义一个数组
                //   let colorList = ['#00a1e0', '#ff8900'];
                //   if (params.dataIndex % 2 == 0) {
                //     return colorList[0]
                //   } else {
                //     return colorList[1]
                //   }
                // },
                // 渐变色
                // color: new this.$echarts.graphic.LinearGradient(
                //   0, 0, 0, 1,
                //   [
                //     {offset: 0, color: '#2B71D9'},
                //     {offset: 1, color: '#3CDAF2'}
                //   ]
                // ),
                // 设置不同颜色
                color: function (params) {
                  let colorList = [
                    '#C1232B', '#B5C334', '#FCCE10', '#E87C25', '#27727B',
                    '#FE8463', '#9BCA63', '#FAD860', '#F3A43B', '#60C0DD',
                    '#D7504B', '#C6E579', '#F4E001', '#F0805A', '#26C0C0'
                  ];
                  return colorList[params.dataIndex]
                },
                barBorderRadius: [8, 8, 8, 8],
                label: {
                  show: true,
                  position: 'top',
                  fontSize: 12,
                  // color: "#00a1e0"
                  // formatter: '{b}\n{c}'
                  formatter: '{c}'
                },
              }
            },
          }]

 高度跟随数据长度自适应

  <div style="height: 8rem;overflow-y: scroll">
    <div class="office" id="office"></div>
  </div>
          this.$echarts.dispose(document.getElementById('office'));
          let myChart = this.$echarts.init(document.getElementById('office'));
          myChart.setOption(option);
          // 柱状图y轴的长度 option.yAxis.data.length
          this.autoHeight = option.yAxis[0].data.length * 20 + 120;
          // 获取 ECharts 实例容器的 dom 节点。
          myChart.getDom().style.height = this.autoHeight + "px";
          myChart.getDom().childNodes[0].style.height = this.autoHeight + "px";
          myChart.getDom().childNodes[0].childNodes[0].setAttribute("height",this.autoHeight);
          myChart.getDom().childNodes[0].childNodes[0].style.height = this.autoHeight + "px";
          myChart.resize();

自动计算最大最小值

yAxis:[
       max: (value) => {
           return value.max
       },
       min: (value) => {
            return value.min
       }
]

X轴出现负数不美观的处理,如下

axisLine: {
      onZero: false
}

 x轴刻度显示间隔问题

xAxis: [
          {
            axisLabel: {
              interval: 0
            }
          }
        ],

 数据范围从左到右展示

        dataZoom: {
          show: true,
          // 百分比
          start: 1,
          end: val.length,
          type: 'inside',
          filterMode: 'filter'
        },

 取消绘制动画

let option = {
   animation: false

 环形图字体居中

        title: {
          text: 名字,
          textStyle: {
            fontSize: 12
          },
          left: '42%',
          top: '35%'
        }

 单独设置字体颜色

yAxis: [
          {
            type: 'category',
            data: shopName.reverse(),
            axisLine: {show: false},
            axisTick: [
              {
                //坐标轴小标记
                show: false
              }
            ],
            axisLabel: {
              // color: "#858585",
              formatter: function (value, index) {
                if (value === '京东自营') {
                  return '★' + value;
                } else {
                  return value
                }
              },
              textStyle: {
                // 设置分段颜色
                color: function (value) {
                  if (value === '京东自营') {
                    return '#ff0000'
                  } else {
                    return '#858585'
                  }
                }
              }
            }
          }
      ]

 无数据展示

// echarts无数据展示
document.getElementById('years').innerHTML = '-暂无相关数据-';
document.getElementById('years').style.cssText = 'text-align:center; color: #999; border: none;line-height:3rem';
document.getElementById('years').removeAttribute('_echarts_instance_');

 

posted @ 2019-07-12 09:32  ronle  阅读(969)  评论(0编辑  收藏  举报