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_');