配置项如下
var data = [{
name: '杭州市',
value: (Math.random() * 100).toFixed(2)
},
{
name: '宁波市',
value: (Math.random() * 100).toFixed(2)
},
{
name: '温州市',
value: (Math.random() * 100).toFixed(2)
},
]
var imgs=[
'',
''
,''
]
var colors = [
{color1:'rgba(31,46,61,1)',color2:'rgba(255,71,71,1)'},
{color1:'rgba(30,46,61,1)',color2:'rgba(255,101,25,1)'},
{color1:'rgba(27,42,54,1)',color2:'rgba(205,183,0,1)'},
]
var data = data.sort((a, b) => b.value - a.value);
var max = Math.max(...data.map(item => item.value));
var xAxis = [],
yAxis = [],
series = [];
yAxis.push({
type: 'category',
axisLine: {
show: false
},
axisLabel: {
verticalAlign: 'bottom',
align: 'left',
padding: [0, 0, 15, 10],
color: '#fff',
fontSize: '16',
formatter: (p, index) => {
var sIndex = data.map(item => item.name).indexOf(p);
return '{index'+index+'|} ' + p;
},
rich: {
index0: {
width:20,
height:20,
backgroundColor:{
image:imgs[0]
}
},
index1: {
width:20,
height:20,
backgroundColor:{
image:imgs[1]
}
},
index2: {
width:20,
height:20,
backgroundColor:{
image: imgs[2]
}
}
}
},
axisTick: {
show: false
},
inverse: true,
data: data.map(item => item.name)
})
yAxis.push({
type: 'category',
axisLine: {
show: false
},
axisLabel: {
verticalAlign: 'bottom',
align: 'right',
padding: [0, 0, 15, 10],
textStyle: {
color: '#fff',
fontSize: '26',
},
formatter: '{value}'+'件'
},
axisTick: {
show: false
},
inverse: true,
data: data.map(item => item.value)
})
series.push({
type: 'bar',
barWidth: 10,
xAxisIndex: 0,
yAxisIndex: 0,
zlevel: 1,
data: data.map((item,i)=>{
item.itemStyle = {
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{
offset: 0,
color: colors[i].color1 // 0% 处的颜色
}, {
offset: 1,
color: colors[i].color2 // 100% 处的颜色
}], false),
barBorderRadius: 5
}
return item;
})
})
series.push({
type: 'bar',
barWidth: 10,
xAxisIndex: 0,
yAxisIndex: 1,
itemStyle: {
color: 'rgba(50,67,79,1)',
barBorderRadius: 5
},
barGap: '-100%',
zlevel: 0,
data: (new Array(data.length)).fill(max)
})
option = {
backgroundColor:'rgba(0,0,0,.5)',
legend: {
show: false
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
grid: {
left: 0,
top: 0,
containLabel: true
},
yAxis: yAxis,
xAxis: {
show: false,
type: 'value',
max: max,
axisLine: {
show: false
},
axisTick: {
show: false
},
splitLine: {
show: false
}
},
series: series
}