不同性别下各个等级人数占比echarts 柱状配置项内容和展示

配置项如下
         var colorList = [
       '#2f54eb',
       '#feb513',
       '#30ca40',
       '#a147eb',
       '#fcec13',
       '#8b572a',
       '#e0109c',
       '#fc605f',
       '#50e3c2',
       '#6879ff',
   ]
   var sum = function(arr) {
       return arr.reduce(function(prev, curr, idx, arr) {
           return prev + curr
       })
   }
   var round = function round(value, decimals) {
       return Number(Math.round(value + 'e' + decimals) + 'e-' + decimals)
   }
   var ratio = function(arr, sum) {
       return arr.map(function(item) {
           return (round(item / sum, 3) * 100).toFixed(1)
       })
   }

   var riskList = [{
       level: "中",
       gender: "女",
       value: 333333
   }, {
       level: "中",
       gender: "男",
       value: 555555
   }, {
       level: "低",
       gender: "女",
       value: 777777
   }, {
       level: "高",
       gender: "男",
       value: 66666
   }, {
       level: "高",
       gender: "女",
       value: 999999
   }, {
       level: "低",
       gender: "男",
       value: 222222
   }]
   // var count = 0
   var man = riskList.filter(x => {
       return x.gender === '男'
   })
   var woman = riskList.filter(x => {
       return x.gender === '女'
   })
   var womanlist = []
   var manlist = []
   // 根据 排序数组
   var orderRiskList = ['高', '中', '低']
   orderRiskList.forEach(x => {
       var m = 0
       man.forEach(item => {
           if (item.level === x) {
               m = item.value
           }
       })
       manlist.push(m)
       var f = 0
       woman.forEach(item => {
           if (item.level === x) {
               f = item.value
           }
       })
       womanlist.push(f)
   })
   // 更改数据,以便tooltip显示
   var mRatio = ratio(manlist, sum(manlist))
   var fRatio = ratio(womanlist, sum(womanlist))
   var mData = []
   var fData = []
   var blankData = []
   for (var i = 0; i < orderRiskList.length; i++) {
       mData.push({
           name: orderRiskList[i],
           value: isNaN(Number(mRatio[i])) ? '' : mRatio[i],
           // value: 0,
           value2: manlist[i],
           tooltip: {
               formatter: function(params) {
                   var s = ''
                   s += '等级:' + params.data.name + '</br>'
                   s += '人数: ' + Number(params.data.value2).toLocaleString() + '</br>'
                   s += '占比: ' + params.data.value + '%'
                   return s
               }
           }
       })
       fData.push({
           name: orderRiskList[i],
           value: isNaN(Number(fRatio[i])) ? '' : fRatio[i],
           value2: womanlist[i],
           tooltip: {
               formatter: function(params) {
                   var s = ''
                   s += '等级:' + params.data.name + '</br>'
                   s += '人数: ' + Number(params.data.value2).toLocaleString() + '</br>'
                   s += '占比: ' + params.data.value + '%'
                   return s
               }
           }
       })
       blankData.push({
           value: 100,
           tooltip: {
               formatter: function(params) {
                   return ''
               }
           }
       })
   }

   option = {
       baseOption: {
           title: {
               text: '不同性别下各个等级人数占比',
               left: 'center',
               textStyle: {
                   fontSize: 18,
                   fontWeight: 700
               }
           },
           tooltip: {
               trigger: 'item'
           },
           timeline: {
               show: false,
               top: 0,
               data: []
           },
           grid: [{
                   show: false,
                   left: '5%',
                   top: '20',
                   bottom: '20%',
                   containLabel: true,
                   width: '37%'
               },
               {
                   show: false,
                   left: '52%',
                   top: '20',
                   bottom: '20%',
                   width: '0%'
               },
               {
                   show: false,
                   right: '2%',
                   top: '20',
                   bottom: '20%',
                   containLabel: true,
                   width: '37%'
               }
           ],
           xAxis: [{
                   type: 'value',
                   inverse: true,
                   axisLine: {
                       show: false
                   },
                   axisTick: {
                       show: false
                   },
                   position: 'top',
                   axisLabel: {
                       show: false
                   },
                   splitLine: {
                       show: false
                   }
               },
               {
                   gridIndex: 1,
                   show: false
               },
               {
                   gridIndex: 2,
                   axisLine: {
                       show: false
                   },
                   axisTick: {
                       show: false
                   },
                   position: 'top',
                   axisLabel: {
                       show: false
                   },
                   splitLine: {
                       show: false
                   }
               }
           ],
           yAxis: [{
                   type: 'category',
                   inverse: true,
                   position: 'right',
                   axisLine: {
                       show: false
                   },
                   axisTick: {
                       show: false
                   },
                   axisLabel: {
                       show: false
                   },
                   data: orderRiskList
               },
               {
                   gridIndex: 1,
                   type: 'category',
                   inverse: true,
                   position: 'left',
                   axisLine: {
                       show: false
                   },
                   axisTick: {
                       show: false
                   },
                   axisLabel: {
                       show: true,
                       textStyle: {
                           color: '#333',
                           fontSize: 14
                       }
                   },
                   data: orderRiskList.map(function(value) {
                       return {
                           value: value,
                           textStyle: {
                               align: 'center'
                           }
                       }
                   })
               },
               {
                   gridIndex: 2,
                   type: 'category',
                   inverse: true,
                   position: 'left',
                   axisLine: {
                       show: false
                   },
                   axisTick: {
                       show: false
                   },
                   axisLabel: {
                       show: false
                   },
                   data: orderRiskList
               }
           ],
           series: []
       },
       options: [{
           series: [{
                   type: 'bar',
                   xAxisIndex: 0,
                   yAxisIndex: 0,
                   itemStyle: {
                       normal: {
                           show: false,
                           color: 'rgba(65, 217, 199, 0.1)',
                           borderWidth: 0
                       },
                       emphasis: {
                           color: 'rgba(65, 217, 199, 0.1)'
                       }
                   },
                   barGap: '-100%',
                   barWidth: '50%',
                   data: blankData
               },
               {
                   name: '男',
                   type: 'bar',
                   xAxisIndex: 0,
                   yAxisIndex: 0,
                   itemStyle: {
                       normal: {
                           show: true,
                           color: function(params) {
                               return colorList[params.dataIndex]
                           },
                           borderWidth: 0,
                           borderColor: '#f8d517'
                       }
                   },
                   label: {
                       normal: {
                           show: true,
                           formatter: (series) => {
                               return mData[series.dataIndex].value + '%'
                           },
                           position: 'left',
                           textStyle: {
                               color: '#223273',
                               fontSize: 14
                           }
                       }
                   },
                   barWidth: '50%',
                   data: mData,
                   markPoint: {
                       symbol: 'image://' +
                           'wOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHZpZXdCb3g9' +
                           'IjAgMCAzNi45OTkgNzEuNDgiPgogIDxkZWZzPgogICAgPHN0eWxlPgogICAgICAuY2xzLTEgewogICAgICAgIGZpbGw6IHVybCgjb' +
                           'GluZWFyLWdyYWRpZW50KTsKICAgICAgfQogICAgPC9zdHlsZT4KICAgIDxsaW5lYXJHcmFkaWVudCBpZD0ibGluZWFyLWdyYWRpZW' +
                           '50IiB4MT0iMC41IiB5MT0iLTAuMzU2IiB4Mj0iMC41IiB5Mj0iMSIgZ3JhZGllbnRVbml0cz0ib2JqZWN0Qm91bmRpbmdCb3giPgo' +
                           'gICAgICA8c3RvcCBvZmZzZXQ9IjAiIHN0b3AtY29sb3I9IiMxYmM4ZmMiIHN0b3Atb3BhY2l0eT0iMC43OCIvPgogICAgICA8c3Rv' +
                           'cCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiMwMTg0YjkiIHN0b3Atb3BhY2l0eT0iMC42OTQiLz4KICAgIDwvbGluZWFyR3JhZGllb' +
                           'nQ+CiAgPC9kZWZzPgogIDxwYXRoIGlkPSLot6/lvoRfMjM1IiBkYXRhLW5hbWU9Iui3r+W+hCAyMzUiIGNsYXNzPSJjbHMtMSIgZD' +
                           '0iTTEyLjg5MSwxNDguMzc5QTE4Ljg3NiwxOC44NzYsMCwwLDAsMCwxNjYuNDg2djEyLjkyMWExLjE2NywxLjE2NywwLDAsMCwxLjE' +
                           '1NiwxLjE1Nkg3LjM5NHYxNS42YS45NzQuOTc0LDAsMCwwLC45NzguOTYzSDI4LjYyN2EuOTc0Ljk3NCwwLDAsMCwuOTc4LS45NjN2' +
                           'LTE1LjZoNC44MTZBMi41OCwyLjU4LDAsMCwwLDM3LDE3Ny45ODRWMTY1LjMzYzAtMTEuNjQ3LTEyLjEyMS0yMC43NDUtMjQuMTA4L' +
                           'TE2Ljk1MVoiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAgLTEyNS42NDkpIi8+CiAgPHBhdGggaWQ9Iui3r+W+hF8yMzYiIGRhdGEtbm' +
                           'FtZT0i6Lev5b6EIDIzNiIgY2xhc3M9ImNscy0xIiBkPSJNNzMuOCwxMC43QTEwLjc1LDEwLjc1LDAsMSwwLDYzLjA1OCwyMS40LDE' +
                           'wLjc0NCwxMC43NDQsMCwwLDAsNzMuOCwxMC43Wm0wLDAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC00NC41NSkiLz4KPC9zdmc+Cg==',
                       symbolSize: [25, 50],
                       label: {
                           position: 'right',
                           padding: [0, 0, 0, 10],
                           fontSize: 12,
                           color: '#333333',
                           formatter: '男'
                       },
                       // markPoint 图片的位置
                       data: [{
                           name: '某个屏幕坐标',
                           x: '30%',
                           y: '85%'
                       }],
                       silent: true
                   }
               },
               {
                   type: 'bar',
                   xAxisIndex: 2,
                   yAxisIndex: 2,
                   itemStyle: {
                       normal: {
                           show: true,
                           color: 'rgba(65, 217, 199, 0.1)',
                           borderWidth: 0
                       },
                       emphasis: {
                           color: 'rgba(65, 217, 199, 0.1)'
                       }
                   },
                   barGap: '-100%',
                   barWidth: '50%',
                   data: blankData
               },
               {
                   name: '女',
                   type: 'bar',
                   xAxisIndex: 2,
                   yAxisIndex: 2,
                   itemStyle: {
                       normal: {
                           show: true,
                           color: function(params) {
                               return colorList[params.dataIndex]
                           },
                           borderWidth: 0,
                           borderColor: '#f39c11'
                       }
                   },
                   label: {
                       normal: {
                           show: true,
                           formatter: (series) => {
                               return fData[series.dataIndex].value + '%'
                           },
                           position: 'right',
                           textStyle: {
                               color: '#223273',
                               fontSize: 14
                           }
                       }
                   },
                   barWidth: '50%',
                   data: fData,
                   markPoint: {
                       symbol: 'image://' +
                           'rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2aWV3Qm94PSIwIDAgMzcuOTYgNjkuNSI+CiAgPGRlZnM+CiAgICA8c3R5' +
                           'bGU+CiAgICAgIC5jbHMtMSB7CiAgICAgICAgZmlsbDogdXJsKCNsaW5lYXItZ3JhZGllbnQpOwogICAgICB9CiAgICA8L3N0eWxlP' +
                           'gogICAgPGxpbmVhckdyYWRpZW50IGlkPSJsaW5lYXItZ3JhZGllbnQiIHgxPSIwLjUiIHgyPSIwLjUiIHkyPSIxIiBncmFkaWVudF' +
                           'VuaXRzPSJvYmplY3RCb3VuZGluZ0JveCI+CiAgICAgIDxzdG9wIG9mZnNldD0iMCIgc3RvcC1jb2xvcj0iIzAzZWJiNyIvPgogICA' +
                           'gICA8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiMwMGEzN2YiIHN0b3Atb3BhY2l0eT0iMC42OTQiLz4KICAgIDwvbGluZWFy' +
                           'R3JhZGllbnQ+CiAgPC9kZWZzPgogIDxnIGlkPSLnu4RfMjkwOSIgZGF0YS1uYW1lPSLnu4QgMjkwOSIgdHJhbnNmb3JtPSJ0cmFuc' +
                           '2xhdGUoMC4wNjIpIj4KICAgIDxwYXRoIGlkPSLot6/lvoRfMjM3IiBkYXRhLW5hbWU9Iui3r+W+hCAyMzciIGNsYXNzPSJjbHMtMS' +
                           'IgZD0iTTc5LjQzNiwxMC40NjdBMTAuNTE4LDEwLjUxOCwwLDEsMCw2OC45MjUsMjAuOTM0LDEwLjUxMiwxMC41MTIsMCwwLDAsNzk' +
                           'uNDM2LDEwLjQ2N1ptMCwwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtNDkuOTg2KSIvPgogICAgPHBhdGggaWQ9Iui3r+W+hF8yMzgi' +
                           'IGRhdGEtbmFtZT0i6Lev5b6EIDIzOCIgY2xhc3M9ImNscy0xIiBkPSJNMzcuNzg1LDE3Ni4wODNsLTUuNzU1LTIyLjVhMTMuNDE5L' +
                           'DEzLjQxOSwwLDAsMC0yNi4xODItLjIxN2wtNS44LDIyLjdhMy44MjUsMy44MjUsMCwwLDAsLjY2NywzLjIxOCwzLjc1OCwzLjc1OC' +
                           'wwLDAsMCwyLjkyOCwxLjQ3OXMyLjgyNy4wNTgsNS4wNi4wNzJjLjcyNSwyLjE0NiwxLjc4Myw1LjI5MiwyLjc1NCw4LjM1QTMuNzI' +
                           'xLDMuNzIxLDAsMCwwLDE1LDE5MS43NjloNy44NThhMy42NzcsMy42NzcsMCwwLDAsMy41MDgtMi41NTJjLjk3MS0zLjA1OSwyLjA1' +
                           'OS02LjMwNiwyLjc2OS04LjQ1MiwyLjIzMy0uMDE1LDUuMDYtLjAyOSw1LjA2LS4wMjlhMy43NjYsMy43NjYsMCwwLDAsMi45MjgtM' +
                           'S40NjQsMy42ODUsMy42ODUsMCwwLDAsLjY2Ny0zLjE4OVptMCwwIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwIC0xMjIuMjY5KSIvPg' +
                           'ogIDwvZz4KPC9zdmc+Cg==',
                       symbolSize: [25, 50],
                       label: {
                           position: 'right',
                           padding: [0, 0, 0, 10],
                           fontSize: 12,
                           color: '#333333',
                           formatter: '女'
                       },
                       // markPoint 图片的位置
                       data: [{
                           name: '某个屏幕坐标',
                           x: '70%',
                           y: '85%'
                       }],
                       silent: true
                   }
               }
           ]
       }]
   }
    
截图如下