vue+echarts 排名

main.js
import * as echarts from 'echarts'

dome
 getInitTwo() {
            var ss = document.getElementById("echartIdone")
            var myEcharts = this.$echarts.init(ss)
            let colorList = ['rgba(0,255,224, 1)', 'rgba(0,255,224, 1)', 'rgba(0,255,224, 1)', 'rgba(0,255,224, 1)', 'rgba(0,255,224, 1)', 'rgba(0,255,224, 1)', 'rgba(0,255,224, 1)', 'rgba(0,255,224, 1)']
            let result = [
                { name: '基地5', value: 580 },
                { name: '基地1', value: 536 },
                { name: '基地2', value: 500 },
                { name: '基地3', value: 350 },
                { name: '基地4', value: 300 },
                { name: '基地8', value: 280 },
                { name: '基地6', value: 240 },
                { name: '基地7', value: 200 },
            ]
            let icons1 = ''
            let icons2 = ''
            let icons3 = ''
            let icons4 = ''

            var option = {
                color: colorList,
                // backgroundColor: '#000416',
                tooltip: {
                    show: true,
                    trigger: 'item',
                    padding: [8, 15],
                    backgroundColor: 'rgba(12, 51, 115,0.8)',
                    borderColor: 'rgba(3, 11, 44, 0.5)',
                    textStyle: {
                        color: 'rgba(255, 255, 255, 1)'
                    },
                },
                legend: {
                    show: false,
                },
                grid: {
                    left: 20,
                    right: '12%',
                    top: 10,
                    bottom: 10,
                },
                xAxis: [
                    {

                        splitLine: {
                            show: false,
                        },
                        type: 'value',
                        show: false,
                    },
                ],
                yAxis: [
                    {
                        splitLine: {
                            show: false,
                        },
                        axisLine: {
                            show: false,
                        },
                        type: 'category',
                        axisTick: {
                            show: false,
                        },
                        inverse: true,
                        data: result.map((item) => item.name),
                        axisLabel: {
                            color: '#fff',
                            // fontSize: 14,
                            inside: true,
                            verticalAlign: 'bottom',
                            // margin: 10,
                            lineHeight: 24,
                            formatter: (name, index) => {
                                const id = index + 1;
                                if (id < 4) {
                                    return `{icon${id}|${id}}{name|${name}}`;
                                } else {
                                    return `{count|${id}}{name|${name}}`;
                                }
                            },
                            rich: {
                                icon1: {
                                    width: 25,
                                    height: 14,
                                    padding: [2, 2, 0, 0],
                                    align: 'center',
                                    backgroundColor: {
                                        image: icons1
                                    },
                                    color: '#ffffff',
                                    fontSize: 10,
                                },
                                icon2: {
                                    width: 25,
                                    height: 14,
                                    padding: [2, 2, 0, 0],
                                    align: 'center',
                                    backgroundColor: {
                                        image: icons2
                                    },
                                    color: '#ffffff',
                                    fontSize: 10,
                                },
                                icon3: {
                                    width: 25,
                                    height: 14,
                                    padding: [2, 2, 0, 0],
                                    align: 'center',
                                    backgroundColor: {
                                        image: icons3
                                    },
                                    color: '#ffffff',
                                    fontSize: 10,
                                },
                                count: {
                                    width: 25,
                                    height: 14,
                                    padding: [2, 2, 0, 0],
                                    align: 'center',
                                    backgroundColor: {
                                        image: icons4
                                    },
                                    color: '#ffffff',
                                    fontSize: 10,
                                }
                            },
                        },
                    },
                    {
                        type: 'category',
                        inverse: true,
                        axisTick: 'none',
                        axisLine: 'none',
                        show: true,
                        axisLabel: {
                            textStyle: {
                                color: '#fff',
                                fontSize: 12,
                            },
                            formatter: function (value) {
                                return `{nums|${value}}次 \n {icons|}`;
                                // return value + '%';
                            },
                            rich: {
                                nums: {
                                    color: "#ffffff"
                                },
                                icons: {
                                    width: 10,
                                    height: 4,
                                    padding: [0, 0, 0, 0],
                                    align: 'right',
                                    backgroundColor: '#00ffea',
                                }
                            }
                        },
                        data: result.map((item) => item.value),
                    },
                ],
                series: [
                    {
                        name: '',
                        type: 'bar',
                        barWidth: 6, // 柱子宽度
                        MaxSize: 0,
                        showBackground: true,
                        barBorderRadius: [30, 0, 0, 30],
                        backgroundStyle: {
                            color: '#194B72',
                        },
                        label: {
                            show: true,
                            position: 'insideRight',
                            distance: -15,
                            formatter: function (params) {
                                console.log(params)
                                return `{a|}`;
                            },
                            rich: {
                                a: {
                                    width: 30,
                                    height: 30,
                                    backgroundColor: {
                                        image: "",
                                    }
                                }
                            }
                        },
                        data: result.map((item, index) => {
                            return {
                                name: item.name,
                                value: item.value,
                                itemStyle: {
                                    barBorderRadius: [30, 30, 30, 30],
                                    color: {
                                        type: "linear",
                                        x: 0,
                                        y: 0,
                                        x2: 1,
                                        y2: 1,
                                        colorStops: [
                                            {
                                                offset: 0,
                                                color: "#0F1F45",
                                            },
                                            {
                                                offset: 1,
                                                color: colorList[index],
                                            },
                                        ],
                                    }
                                }
                            }
                        }),
                    },
                    

                ],
            }
            myEcharts.setOption(option)
            window.addEventListener("resize", () => {
                myEcharts.resize();
            });

        },

  • 8
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值