let ranking1 = ``; let ranking2 = `` let ranking3 = `` let ranking4 = `` let left2 = [{ name: "租赁和商务服务业", num: 1234, num1: 1234 }, { name: "科学研究和技术服务业", num: 123, num1: 1234 }, { name: "交通运输、仓储和邮政业", num: 500, num1: 1234 }, { name: "信息传输、软件和信息技术服务业", num: 345, num1: 1234 }, { name: "批发和零售业", num: 4356, num1: 1234 }, { name: "采矿业", num: 2345, num1: 1234 }, { name: "制造业", num: 12111, num1: 1234 }, { name: "电力、热力、燃气及水生产和供应业", num: 5673, num1: 1234 }] const dataZoomMove = { start: 0, end: 4 } const dataSource = left2; option ={ backgroundColor:'#000', legend: { data: ['总量', '每天'], left: 'center', top: 'top', itemWidth: 12, itemHeight: 10, textStyle: { color: '#E3D8CB', fontSize: '14px' } }, tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' }, backgroundColor: 'rgba(21, 60, 142, 0.8)', borderColor: '#4DFFEA', borderWidth: 1, borderRadius: 5, textStyle: { color: '#BCE9FC', fontSize: 14, align: 'left' }, confine: true }, grid: { left: '110', right: '13%', top: '5%', bottom: '1%' }, xAxis: { show: false }, yAxis: [ { gridIndex: 0, position: 'left', splitLine: { show: false }, axisLine: { show: false }, type: 'category', axisTick: { show: false }, inverse: true, data: dataSource.map((item, index) => index + 1), axisLabel: { align: 'left', padding: [0, 0, 0, -90], formatter: (index) => { const id = index if (id < 4) { return `{icon${id}|${id}}` } else { return `{count|${id}}` } }, rich: { icon1: { width: 21, padding: [0, 5, 0, 0], height: 20, fontSize: 12, color: '#fff', align: 'center', borderRadius: 50, backgroundColor: { image: ranking1 } }, icon2: { width: 21, padding: [0, 5, 0, 0], height: 20, color: '#fff', fontSize: 12, align: 'center', borderRadius: 50, backgroundColor: { image: ranking2 } }, icon3: { width: 21, padding: [0, 5, 0, 0], height: 20, color: '#fff', fontSize: 12, align: 'center', backgroundColor: { image: ranking3 } }, count: { width: 21, height: 20, color: '#fff', fontSize: 12, padding: [0, 5, 0, 0], align: 'center', backgroundColor: { image: ranking4 } } } } }, { gridIndex: 0, position: 'left', splitLine: { show: false }, axisLine: { show: false }, type: 'category', axisTick: { show: false }, inverse: true, data: dataSource.map((item, index) => item.name), axisLabel: { align: 'center', padding: [0, 0, 0, -30], formatter: (name, index) => { const paramsNameNumber = name.length const provideNumber = 3// 一行显示几个字 let nameNew = '' if (paramsNameNumber > provideNumber) { nameNew = name.substring(0, 3) + '...' } else { nameNew = name } const id = index + 1 if (id < 4) { return `{name|${nameNew}}` } else { return `{name|${nameNew}}` } }, rich: { name: { width: 70, color: '#fff', height: 25, align: 'left', fontSize: 14 } } } }, { type: 'category', inverse: true, splitLine: { show: false }, axisTick: { show: false }, axisLine: { // 改变y轴颜色 show: false }, data: dataSource.map((item) => item.num), axisLabel: { verticalAlign: 'bottom', align: 'right', padding: [0, -60, 0, 0], textStyle: { color: '#14F7FF', fontSize: 14 }, formatter: function (value) { return value + '万' } } }, { type: 'category', inverse: true, splitLine: { show: false }, axisTick: { show: false }, axisLine: { // 改变y轴颜色 show: false }, data: dataSource.map((item) => item.num1), axisLabel: { verticalAlign: 'top', align: 'right', padding: [6, -60, 0, 0], textStyle: { color: '#2EA6FF', fontSize: 14 }, formatter: function (value) { return value + '万' } } } ], dataZoom: [ { show: false, // 为true 滚动条出现 realtime: true, type: 'slider', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。 height: '90%', // 表示滚动条的高度,也就是粗细 startValue: dataZoomMove.start, // 表示默认展示20%~80%这一段。 endValue: dataZoomMove.end, width: 6, right: '26%', top: '1%', // 位置和grid配置注意下 // height: '56%', yAxisIndex: [0, 1, 2, 3], // 关联多个y轴 moveHandleStyle: { color: 'rgba(89, 202, 241,.5)' }, moveHandleSize: '6', emphasis: { moveHandleStyle: { color: 'rgba(89, 202, 241,.5)' } }, textStyle: { color: 'rgba(255,255,255,0)' }, backgroundColor: 'rgba(255,255,255,.1)', borderColor: 'rgba(255,255,255,0)', fillerColor: 'rgba(0,0,0,0)', handleSize: '6', handleStyle: { color: 'rgba(255,255,255,0)' }, brushStyle: { color: 'rgba(129, 243, 253)' } }, { // 没有下面这块的话,只能拖动滚动条,鼠标滚轮在区域内不能控制外部滚动条 type: 'inside', yAxisIndex: 0, zoomOnMouseWheel: false, // 滚轮是否触发缩放 moveOnMouseMove: true, // 鼠标滚轮触发滚动 moveOnMouseWheel: true } ], series: [ { name: '总量', type: 'bar', barWidth: 12, // 柱子宽度 showBackground: true, barGap: '60%', barCategoryGap: '60%', backgroundStyle: { color: 'rgba(58,69,75, 1)', borderRadius: 30 }, itemStyle: { normal: { label: { show: false // 开启显示 }, barBorderRadius: 30, borderWidth: 2, color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{ offset: 0, color: '#063863' }, { offset: 1, color: '#14F7FF' }]) } }, data: dataSource.map((item, index) => item.num) }, { name: '每天', type: 'bar', barWidth: 12, // 柱子宽度 showBackground: true, barGap: '60%', barCategoryGap: '60%', backgroundStyle: { color: 'rgba(58,69,75, 1)', borderRadius: 30 }, itemStyle: { normal: { label: { show: false // 开启显示 }, barBorderRadius: 30, borderWidth: 2, color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{ offset: 0, color: '#063863' }, { offset: 1, color: '#2EA6FF' }]) } }, data: dataSource.map((item, index) => item.num1) } ] } let dataZoomMoveTimer = null const startMoveDataZoom = (myChart, dataZoomMove) => { dataZoomMoveTimer = setInterval(() => { dataZoomMove.start += 1 dataZoomMove.end += 1 if (dataZoomMove.end > dataSource.length - 1) { dataZoomMove.start = 0 dataZoomMove.end = 4 } myChart.setOption({ dataZoom: [ { type: 'slider', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。 startValue: dataZoomMove.start, endValue: dataZoomMove.end } ] }) }, 3000) } startMoveDataZoom(myChart, dataZoomMove) const chartDom = myChart.getDom() chartDom.addEventListener('mouseout', () => { if (dataZoomMoveTimer) return const dataZoomMoveget = myChart.getOption().dataZoom[0] dataZoomMove.start = dataZoomMoveget.startValue dataZoomMove.end = dataZoomMoveget.endValue startMoveDataZoom(myChart, dataZoomMove) }) // 移入 // myChart.on chartDom.addEventListener('mouseover', () => { clearInterval(dataZoomMoveTimer) dataZoomMoveTimer = undefined })