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) })