首页 前端知识 Vue中优雅的使用Echarts的三种方式

Vue中优雅的使用Echarts的三种方式

2025-02-25 13:02:09 前端知识 前端哥 208 629 我要收藏

一、原始方法直接使用

1、安装ECharts:

npm install echarts --save

2、创建一个Vue公共组件 EChart.vue:

<template>
<div :style="{width: '100%', height: '300px'}" ref="chart"></div>
</template>
<script>
import echarts from 'echarts'
export default {
name: 'EChart',
props: {
option: {
type: Object,
required: true
}
},
data() {
return {
chartInstance: null
}
},
watch: {
option: {
handler(newOption) {
if (this.chartInstance) {
this.chartInstance.setOption(newOption);
}
},
deep: true
}
},
mounted() {
this.chartInstance = echarts.init(this.$refs.chart);
this.chartInstance.setOption(this.option);
},
beforeDestroy() {
if (this.chartInstance) {
this.chartInstance.dispose();
}
}
}
</script>
复制

3、使用EChart.vue组件

<template>
<div>
<e-chart :option="chartOption"></e-chart>
</div>
</template>
<script>
import EChart from './EChart.vue'
export default {
components: {
EChart
},
data() {
return {
chartOption: {
// ECharts 配置项
}
}
}
}
</script>
复制

这个例子中,EChart.vue组件通过props接收ECharts的配置项option,并在组件的mounted生命周期钩子中初始化ECharts实例,在watch中监控option的变化,并更新图表。在父组件中,你可以通过传递不同的chartOption来更新图表。

这样做的好处是,你可以在多个地方复用这个图表组件,并通过传递不同的配置来定制图表的显示。同时,组件内部处理了ECharts实例的创建和销毁,使得使用更加简洁和高效。

二、使用vue-echarts

vue-echarts (https://github.com/ecomfe/vue-echarts)是ECharts 的 Vue.js 组件,基于 ECharts v4.1.0+ 开发,依赖 Vue.js v2.2.6+,意思就是可以直接把echarts实例当中vue中的组件来使用,不用每次都获取dom、挂在dom,轻松使用echarts的所用功能。

npm install echarts vue-echart

main.js中引入

import ECharts from 'vue-echarts'
// 注册全局的组件
Vue.component('vChart', ECharts)
复制

vue中使用,直接添加options 数据即可。

<template>
<div class="page">
<el-card>
<!-- 柱状图+折线图 -->
<vChart class="chart3" :options="barOptions" />
</el-card>
</div>
</template>
<script>
export default {
data() {
return {
barOptions: {
color: ["#5094FF", "#64DAAC", "#FAC84A"],
grid: {
top: "15%",
bottom: "20%",
right: "5%",
left: "5%"
},
tooltip: {},
legend: {
data: ["合格数", "超标数", "合格率", "超标率"],
top: "0"
},
xAxis: {
type: "category",
data: ["04-13", "04-14", "04-15", "04-16", "04-17", "04-18", "04-19"]
},
yAxis: {
// name: '合格率(%)',
// nameLocation: 'middle',
type: "value"
// nameTextStyle: {
// fontSize: '0.072917rem',
// color: '#999999'
// }
},
series: [
{
name: "合格数",
type: "bar",
barWidth: "15%",
barGap: "5%",
data: [20, 232, 441, 654, 770, 530, 410]
},
{
name: "超标数",
type: "bar",
barWidth: "15%",
data: [120, 482, 791, 834, 590, 930, 710]
},
{
name: "合格率",
type: "line",
data: [420, 332, 291, 654, 590, 330, 810]
},
{
name: "超标率",
type: "line",
data: [120, 232, 391, 854, 590, 730, 410]
}
]
}
};
}
};
</script>
复制

三、使用v-charts

v-charts(https://v-charts.js.org/#/) 是基于vue2二次封装的图表组件库,功能没有echarts多 但也够用了,官网很详细,这里用一个官网例子说明问题

<template>
<ve-histogram :data="chartData" :settings="chartSettings"></ve-histogram>
</template>
<script>
export default {
data () {
this.chartSettings = {
showLine: ['下单用户']
}
return {
chartData: {
columns: ['日期', '访问用户', '下单用户', '下单率'],
rows: [
{ '日期': '1/1', '访问用户': 1393, '下单用户': 1093, '下单率': 0.32 },
{ '日期': '1/2', '访问用户': 3530, '下单用户': 3230, '下单率': 0.26 },
{ '日期': '1/3', '访问用户': 2923, '下单用户': 2623, '下单率': 0.76 },
{ '日期': '1/4', '访问用户': 1723, '下单用户': 1423, '下单率': 0.49 },
{ '日期': '1/5', '访问用户': 3792, '下单用户': 3492, '下单率': 0.323 },
{ '日期': '1/6', '访问用户': 4593, '下单用户': 4293, '下单率': 0.78 }
]
}
}
}
}
</script>
复制
转载请注明出处或者链接地址:https://www.qianduange.cn//article/21445.html
标签
评论
还可以输入200
共0条数据,当前/页
发布的文章

python调用ollama库详解

2025-02-25 13:02:30

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!