效果图如下:
代码如下:
<template>
<div class="main">
<div class="volume" ref="container"></div>
</div>
</template>
<script>
import echarts from "echarts";
export default {
data() {
return {
myChart: null,
option: null,
data: [
{
name: "1月",
value: 53,
},
{
name: "2月",
value: 24,
},
{
name: "3月",
value: 10,
},
{
name: "4月",
value: 20,
},
{
name: "5月",
value: 10,
},
{
name: "6月",
value: 20,
},
],
opt: {
index: 0,
},
};
},
mounted() {
this.drawChart();
//获取数据。
if (this.$refs.container) {
this.reloadChart();
//自适应浏览器。
window.addEventListener("resize", () => {
this.reloadChart();
});
}
},
//组件销毁。
beforeDestroy() {
this.disposeChart();
},
methods: {
getArrByKey(data, k) {
let key = k || "value";
let res = [];
if (data) {
data.forEach(function(t) {
res.push(t[key]);
});
}
return res;
},
getSymbolData(data) {
let arr = [];
for (var i = 0; i < data.length; i++) {
arr.push({
value: data[i].value,
symbolPosition: "end",
});
}
return arr;
},
drawChart() {
this.myChart = echarts.init(this.$refs.container);
var data = [
{
name: "1月",
value: 53,
},
{
name: "2月",
value: 24,
},
{
name: "3月",
value: 10,
},
{
name: "4月",
value: 20,
},
{
name: "5月",
value: 10,
},
{
name: "6月",
value: 20,
},
];
this.option = {
grid: {
top: "8%",
bottom: 0,
right: "16%",
left: "18%",
containLabel: true,
},
xAxis: {
show: false,
},
yAxis: [
{
triggerEvent: true,
show: true,
inverse: true,
data: this.getArrByKey(this.data, "name"),
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisTick: {
show: false,
},
axisLabel: {
show: false,
interval: 0,
color: "#fff",
align: "left",
margin: 80,
fontSize: this.fontSize(0.35),
formatter: function(value, index) {
return "{title|" + value + "}";
},
},
},
{
triggerEvent: true,
show: true,
inverse: true,
data: this.getArrByKey(this.data, "name"),
axisLine: {
show: false,
},
splitLine: {
show: false,
},
axisTick: {
show: false,
},
axisLabel: {
interval: 0,
shadowOffsetX: "-20px",
color: ["#fff"],
align: "right",
verticalAlign: "bottom",
lineHeight: 0,
fontSize: this.fontSize(0.35),
formatter: function(value, index) {
const totalValue = data.reduce(
(sum, item) => sum + item.value,
0
);
const percentage = (
(data[index].value / totalValue) *
100
).toFixed(0);
return `{percent|${percentage}%}`;
},
rich: {
percent: {
color: "#fff",
fontSize: this.fontSize(0.35),
align: "right",
padding: [0, -this.fontSize(1.6)],
},
},
},
},
],
series: [
{
name: "",
type: "pictorialBar",
symbol:
"image://",
symbolSize: [this.fontSize(0.55), this.fontSize(0.55)],
symbolOffset: [this.fontSize(0.25), 0],
z: 12,
itemStyle: {
normal: {
color: "#14b1eb",
},
},
data: this.getSymbolData(this.data),
},
{
name: "条",
type: "bar",
showBackground: false,
barBorderRadius: 30,
yAxisIndex: 0,
data: data,
barWidth: this.fontSize(0.18),
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
1,
0,
[
{
offset: 0,
color: "rgba(31, 89, 89, 0.25)",
},
{
offset: 1,
color: "rgba(51, 204, 204, 1)",
},
],
false
),
barBorderRadius: 0,
},
barBorderRadius: 4,
},
label: {
normal: {
color: "#fff",
show: true,
position: [-this.fontSize(1.2), "0px"],
textStyle: {
color: "#D9F9FF",
fontSize: this.fontSize(0.35),
},
formatter: function(a, b) {
return a.name;
},
},
},
},
],
};
this.myChart.setOption(this.option);
},
//字体自适应。
fontSize(res) {
let clientWidth =
window.innerWidth ||
document.documentElement.clientWidth ||
document.body.clientWidth;
if (!clientWidth) return;
let fontSize = 40 * (clientWidth / 1920);
return res * fontSize;
},
//销毁图表。
disposeChart() {
if (this.myChart) {
this.myChart.dispose();
}
},
//重新加载图表。
reloadChart() {
this.disposeChart();
this.drawChart();
},
},
};
</script>
<style lang="scss" scoped>
.main {
width: 100%;
height: 100%;
.volume {
width: 100%;
height: 100%;
}
}
</style>