vue加echarts(vue3+Echarts页面加载不渲染显示空白页面的解决)
导读:vue3 Echarts页面加载不渲染显示空白页面 在父组件获取到数据后传递给子组件并没有及时的更新渲染图表。...
vue3 Echarts页面加载不渲染显示空白页面
在父组件获取到数据后传递给子组件并没有及时的更新渲染图表 。
在本地开发环境是没有一点问题 ,但发布到测试环境上每次页面加载都不渲染 ,点击浏览器刷新按钮后才会去渲染图表 。
个人认为造成这个问题的原因
页面加载子组件dom元素此时还没有加载完成 ,所以看到的就是空白 ,只有刷新一下才可以 。
解决这个问题的方法
在生命周期里面使用 nextTick()待dom加载完成之后再去渲染图表```
具体实现代码:
父组件:
获取到数据后通过props 传递给子组件
```javascript
<!--入驻统计折线图-->
<hostLine ref="settled" :settledData="settledData"> </hostLine>
// 获取入驻统计
async getSettledData() {
const result = await getProjectSettled();
// 如果后台返回的数据是空 前端就渲染一个空表出来 必须等获取到数据以后在渲染 Echarts
if (result.success) {
if (result.data.companyCount.length === 0 && result.data.stationCount.length === 0) {
Object.assign(data.settledData);
} else {
Object.assign(data.settledData, result.data);
}
update.value = new Date().getTime();
}
},
子组件:
接收父组件传递的数据并进行 watch 监听 ,在生命周期onMounted里面使用 nextTick进行渲染图表就行了 。
<template>
<div class="line-overview">
<div class="host-line">
<div class="host-line-title">入驻统计</div>
<div id="hostLine"></div>
</div>
</div>
</template>
<script lang="ts">
import * as echarts from "echarts/core";
import { TooltipComponent, LegendComponent, GridComponent, } from echarts/components;
import { LineChart } from echarts/charts;
import { CanvasRenderer } from echarts/renderers;
import { UniversalTransition } from echarts/features;
import { defineComponent, inject, watch, onMounted, onUnmounted, ref, shallowRef, nextTick } from "vue";
echarts.use([
TooltipComponent,
LegendComponent,
GridComponent,
LineChart,
CanvasRenderer,
UniversalTransition
]);
export default defineComponent({
props: ["settledData"],
setup(props) {
const update = inject("update");
const LineChart = shallowRef();
const drawChart = () => {
const cahrtData = props.settledData;
LineChart.value = echarts.init(document.getElementById("hostLine") as HTMLElement);
// 指定图表的配置项和数据
let option = {
tooltip: {
trigger: "axis",
},
legend: {
data: [企业数量, 工位数量,]
},
grid: {
left: "3%",
right: "4%",
bottom: "3%",
containLabel: true,
},
xAxis: {
type: "category",
boundaryGap: false,
data: cahrtData?.date.reverse()
},
// Y标尺固定
yAxis: {
type: "value",
scale: true,
// // boundaryGap: [0.2, 0.2],
// // 动态设置Y轴的刻度值 只取整数
min: (value:Record<string,number>) => {
return Math.floor(value.min / 100) * 100;
},
max: (value:Record<string,number>) => {
return Math.ceil(value.max / 100) * 100;
},
},
series: [
{
name: "企业数量",
type: "line",
stack: "Total",
data: cahrtData?.companyCount,
},
{
name: "工位数量",
type: "line",
stack: "Total",
data: cahrtData?.stationCount,
},
],
};
// 使用刚指定的配置项和数据显示图表 。
LineChart.value.setOption(option);
window.addEventListener("resize", () => {
LineChart.value.resize();
});
};
onMounted(() => {
watch([update], () => {
nextTick(()=>{
drawChart();
})
}, {
deep: true
})
});
onUnmounted(() => {
LineChart.value.dispose();
});
},
});
</script>
vue Echarts白屏或等一会才出现
原因
由于是异步加载数据 ,setOption的时候div的宽高还是0 ,导致canvas渲染宽高也是0 。
解决方法
加上默认的width和height
<div class="echarts-vue" ></div>
以上为个人经验 ,希望能给大家一个参考 ,也希望大家多多支持本站 。
声明:本站所有文章,如无特殊说明或标注 ,均为本站原创发布 。任何个人或组织 ,在未征得本站同意时,禁止复制 、盗用 、采集 、发布本站内容到任何网站 、书籍等各类媒体平台 。如若本站内容侵犯了原著者的合法权益 ,可联系我们进行处理。
创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!