排行柱状图数据过多加 滚动条

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            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'
            },
         },
      },
   ],
};