let ranking1 = ``; let ranking2 = `` let ranking3 = `` let ranking4 = `` let left2 = [{ name: "租赁和商务服务业", cnt: 1234 }, { name: "科学研究和技术服务业", cnt: 123 }, { name: "交通运输、仓储和邮政业", cnt: 500 }, { name: "信息传输、软件和信息技术服务业", cnt: 345 }, { name: "批发和零售业", cnt: 4356 }, { name: "采矿业", cnt: 2345 }, { name: "制造业", cnt: 12111 }, { name: "电力、热力、燃气及水生产和供应业", cnt: 5673 }, { name: "供应业电力、热力、燃气及水生产和", cnt: 563 }, { name: "热力、电力、燃气及水生产和供应业", cnt: 5687 }] left2.sort(function (a, b) { return b.cnt - a.cnt }) const dataSource = left2; const COLORS = ['#1AF7FF', '#3F9EFF', '#5FCFC4', '#3B65FF'] let attaVal = [] /* 进度条数值 */, topName = [] /* 进度条名称 */, salvProMax = []; /* 背景条数据 */ dataSource.forEach((it, i) => { topName[i] = `${it.name}`; attaVal[i] = it.cnt; }); for (let i = 0; i < attaVal.length; i++) { salvProMax.push(Math.max(...attaVal)) } option = { tooltip: { // trigger: 'item', backgroundColor: "rgba(50,50,50,0.7)", textStyle: { // 提示框浮层的文本样式。 color: "#fff", // fontSize:12 }, }, grid: [ { left: 20, top: 4, right: '8%', bottom: 4, containLabel: true, }, ], xAxis: [ { gridIndex: 0, type: 'value', axisLabel: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, }, { gridIndex: 0, type: 'value', max: 100, axisLabel: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, }, ], dataZoom: [ { show: dataSource.length > 6, startValue: 0, // 数据窗口范围的起始数值 endValue: 6, // 数据窗口范围的结束数值(一页显示多少条数据) type: 'slider', maxValueSpan: 6, // 显示数据的条数(默认显示10个) handleSize: 0, // 滑动条的 左右2个滑动条的大小 height: '90%', // 组件高度 width: '2%', left: '96%', // 左边的距离 right: 4, // 右边的距离 bottom: 10, // 上边边的距离 borderColor: '#0e426c', fillerColor: '#1890ff', // 滑动块的颜色 backgroundColor: '#0e426c', // 两边未选中的滑动条区域的颜色 showDataShadow: false, // 是否显示数据阴影 默认auto showDetail: false, // 即拖拽时候是否显示详细数值信息 默认true realtime: true, // 是否实时更新 filterMode: 'filter', yAxisIndex: [0, 1, 2], // 控制的y轴 brushSelect: false // 刷选功能,设为false可以防止拖动条长度改变 ************(这是一个坑) }, { //没有下面这块的话,只能拖动滚动条,鼠标滚轮在区域内不能控制外部滚动条 type: "inside", yAxisIndex: [0, 1, 2],//控制哪个轴,如果是 number 表示控制一个轴,如果是 Array 表示控制多个轴。此处控制第二根轴 zoomOnMouseWheel: false, //滚轮是否触发缩放 moveOnMouseMove: true, //鼠标移动能否触发平移 moveOnMouseWheel: true,//鼠标滚轮能否触发平移 }, ], yAxis: [ { gridIndex: 0, type: 'category', inverse: true, position: 'left', data: dataSource.map((item, index) => index + 1), axisTick: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisLabel: { align: 'left', padding: [0, 0, 0, -132], show: true, color: "#fff", formatter: (index) => { const id = index if (id < 4) { return `{icon${id}|${id}}`; } else { return `{count|${id}}`; } }, rich: { icon1: { width: 20, height: 20, color: '#fff', align: 'center', borderRadius: 50, backgroundColor: { image: ranking1, }, }, icon2: { width: 20, height: 20, color: '#fff', align: 'center', borderRadius: 50, backgroundColor: { image: ranking2, }, }, icon3: { width: 20, height: 20, shadowColor: '#3374ba', borderColor: '#3374ba', borderWidth: 1, borderRadius: 50, color: '#fff', align: 'center', backgroundColor: { image: ranking3, }, }, count: { padding: [2, 0, 0, 0], width: 20, height: 18, color: '#000', align: 'center', fontSize: 12, fontFamily: 'DIN', fontWeight: 500, shadowColor: '#008AFF', borderColor: '#008AFF', borderRadius: 50, borderWidth: 1, backgroundColor: { image: ranking4, }, }, name: { padding: [0, 6, 0, 6], fontSize: 11, align: 'left', color: '#fff' }, }, } }, { gridIndex: 0, type: 'category', inverse: true, position: 'left', data: dataSource.map((item) => item.name), axisTick: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisLabel: { align: 'left', padding: [0, 0, 0, -106], show: true, formatter: (name, index) => { const paramsNameNumber = name.length const provideNumber = 8 // 一行显示几个字 let nameNew = '' if (paramsNameNumber > provideNumber) { nameNew = name.substring(0, 8) + '...' } else { nameNew = name } const id = index + 1 if (id < 4) { return `{name|${nameNew}}`; } else { return `{name|${nameNew}}`; } }, rich: { name: { padding: [0, 6, 0, 6], fontSize: 11, align: 'left', color: '#fff' }, }, }, }, { gridIndex: 0, type: 'category', inverse: true, axisTick: 'none', axisLine: 'none', show: true, axisLabel: { padding: [0, 0, 0, 2], align: 'left', textStyle: { color: '#73FFF7', fontSize: 12 }, formatter: (params) => { return `${params}` } }, data: dataSource.map((item) => item.cnt) } ], series: [ { z: 1, type: 'bar', barWidth: 10, data: dataSource.map((item) => item.cnt), silent: true, itemStyle: { normal: { color: (item) => { let index = item.dataIndex return index < 4 ? COLORS[index] : "#3B65FF" }, }, }, }, { z: 3, name: '', type: 'bar', barWidth: 10, barGap: '-100%', data: salvProMax, itemStyle: { normal: { color: 'rgba(131, 132, 132, 0.1)', // barBorderRadius: [30, 30, 30, 30], borderColor: '#3F9EFF', borderWidth: '0.3' }, }, }, ], };