Vue项目中开发数据大屏,使用echarts图表根据不同尺寸的屏幕进行适配
亿点小知识:可以在opts 中显示指定图表高宽
1.创建容器
<div ref="myChart" style="width:100%;height:100%"></div>
2.创建echarts
先创建一个 echartsLine.ts 文件
import { EChartsOption } from "echarts";
const exportFuns = (): EChartsOption => {
return {
xAxis: {
type: 'category',
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
yAxis: {
type: 'value'
},
series: [
{
data: [150, 230, 224, 218, 135, 147, 260],
type: 'line'
}
]
}
};
export const EchartsLineConsumption = exportFuns();
在容器组件里面应用echartsLine.ts 文件
<script lang="ts" setup>
import { ref, onMounted, markRaw } from "vue";
import * as echarts from "echarts";
import { EchartsLineConsumption } from "@/config/echartsLine";
const myChart = ref<any>(); // 获取元素实例
const line = ref<any>(null); // 获取echarts
onMounted(() => {
init();
});
const init = ()=>{
line.value = markRaw(echarts.init(myChart.value));
line.value.setOption(EchartsLineConsumption);
}
</script>
3.进行响应式页面变化.resize()
onMounted(() => {
// 只要窗口大小发生像素变化就会触发
window.addEventListener("resize", () => {
line.value.resize(); // 窗口发生改变就更新echarts
});
init();
});
4.需要进行销毁实例优化性能
onUnmounted(() => {
// 卸载echarts实例
line.value.dispose();
window.removeEventListener("resize", line.value);
});
以上就完成了 Vue中 echarts响应式页面变化
接下来总结了一下echarts的一些常用知识
type: "pie",
radius: ["47%", "57%"], // 让饼图中间为空心状
label: {
show: true,
position: "center",
formatter: "中间圆心内容",
fontSize: '18px',
},
grid: {
// 让图表占满容器
left: 0,
right: 0,
bottom: 0,
containLabel: true,
},
tooltip: {
position: "top",
show: true,
formatter: (params) => {
//只有“直接访问”使用大标签,其他都使用小标签
return `$标题<br/>${params.marker}`;//marker 图标
},
// extraCssText:'width:60px;white-space:pre-wrap'
},
legend: {
orient: "horizontal",
bottom: '5px',
left: "left",
icon: "circle",
itemGap: 2,
},
以上就是echarts响应式页面变化.resize()感谢大家的阅读
如碰到其他的问题 可以私下我 一起探讨学习
如果对你有所帮助还请 点赞
收藏谢谢~!
关注收藏博客 作者会持续更新…