配置项如下
let myicon = 'image://';
let startValue = '';
let endValue = '';
let start = ''; //起始X轴
let end = ''; //结束X轴
option = {
backgroundColor: '#fff',
legend: {
data: ['雨量'],
itemHeight: 2,
itemWidth: 15,
borderRadius: 5,
textStyle: { //图例文字的样式
color: '#3C4353',
fontSize: 12
},
},
graphic: [{ //图形中间文字
type: "text",
left: 81,
bottom: 9,
style: {
text: "2020-09-15 00:00:00",
textAlign: "center",
fill: "#838A9D",
fontSize: 12
}
}, { //图形中间文字
type: "text",
right: 53,
bottom: 9,
style: {
text: "2020-09-15 00:00:00",
textAlign: "center",
fill: "#838A9D",
fontSize: 12
}
}],
dataZoom: [{
type: 'slider',
xAxisIndex: 0,
filterMode: 'filter',
height: 4,
bottom: 35,
handleSize: "400%",
handleIcon: myicon,
handleStyle: {
color: "#46C7DC",
},
backgroundColor: "#F0F2F5",
fillerColor: "#46C7DC",
borderColor: "transparent",
textStyle: {
color: "transparent"
},
dataBackground: {
areaStyle: {
opacity: 0
},
lineStyle: {
opacity: 0
}
},
},
{
type: 'slider',
yAxisIndex: 0,
filterMode: 'none',
left: 45,
handleSize: "400%",
width: 4,
handleIcon: myicon,
handleStyle: {
color: "#46C7DC",
},
backgroundColor: "#F0F2F5",
fillerColor: "#46C7DC",
borderColor: "transparent",
textStyle: {
color: "transparent"
},
dataBackground: {
areaStyle: {
opacity: 0
},
lineStyle: {
opacity: 0
}
},
},
],
tooltip: {
position: 'top',
padding: [13, 16],
formatter(params) {
const marker = '<span style="width: 15px;height: 2px;background: #648EED;border-radius: 4px;display:inline-block;margin-bottom:3px;margin-right:7px;"></span>';
return '2020-09-15 20:00:00' + '<br>' + marker + '雨量:' + params.value
},
textStyle: {
align: 'center',
}
// formatter:'{a}/{b}/{c}',
},
xAxis: [{
// name: start,
type: 'category',
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
axisLine: {
lineStyle: {
color: '#3C4353',
}
},
axisLabel: {
show: false,
formatter: function(value, index) {
if (value == start || value == end) {
console.log(value, index)
return value
} else {
return ''
}
}
}
}],
yAxis: [{
name: '雨量mm',
nameTextStyle: {
color: "#3C4353",
fontSize: 12,
},
type: 'value',
// interval: 2.5,
minInterval: 2.5,
splitNumber:10,
axisTick: {
"show": false
},
splitLine: {
"show": true,
lineStyle: {
color: "rgba(221, 226, 238, 0.5)",
},
},
axisLabel: {
show: true,
textStyle: {
color: '#838A9D',
fontSize: 12,
}
},
axisLine: {
lineStyle: {
color: '#DDE2EE',
}
},
}],
series: [{
name: '雨量',
data: [9, 7.2, 11, 15, 22, 3.3, 0.2],
type: 'bar',
barWidth: 18,
showBackground: false,
itemStyle: {
normal: {
color: '#648EED',
},
},
}],
};
myChart.setOption(option);
let option2 = myChart.getModel().option;
startValue = option2.dataZoom[0].startValue;
endValue = option2.dataZoom[0].endValue;
start = option2.xAxis[0].data[startValue]; //起始X轴
end = option2.xAxis[0].data[endValue]; //结束X轴
console.log("开始值=" + start);
console.log("结束值=" + end);
myChart.on('dataZoom', function(params) {
let option3 = myChart.getModel().option;
startValue = option3.dataZoom[0].startValue;
endValue = option3.dataZoom[0].endValue;
start = option3.xAxis[0].data[startValue]; //起始X轴
end = option3.xAxis[0].data[endValue]; //结束X轴
console.log("开始值=" + start);
console.log("结束值=" + end);
option.graphic[0].style.text = start
option.graphic[1].style.text = end
myChart.setOption(option)
})