Vue3 对于echarts使用 v-show,导致显示不全,宽度仅100px,无法重新渲染的问题

参考链接:
解决Echarts图表使用v-show,显示不全,宽度仅100px的问题_echarts v-show图表不全-CSDN博客

Vue3 echarts v-show无法重新渲染的问题_v-show echarts不渲染-CSDN博客

原因不多赘述了,大概就是v-show 本身是结构已经存在,当数据发生变化时,结构并未重新渲染,所以会出现 echarts 图表未获取到最外层大盒子的宽度而显示一半的情况,就像下图(截的别人的图):

方法一:将 v-show 改成 v-if

但是我做的功能涉及频繁切换,以及更换成v-if后会导致图表的初始化找不到dom, 遂放弃。

方法二:使用nextTick(() => {})函数

首先需要从vue中引入:

TypeScript 复制代码
<script lang="tsx" setup>

import {nextTick} from 'vue';


</script>

然后就是在需要切换v-show状态的地方:

TypeScript 复制代码
<template>

// 放echart图的div
<div v-show="isData" ref="chartRef" style="width:45%; height=400px"></div>

// 切换按钮
<button @click="changeButton">切换按钮</button>

</template>


<script lang="tsx" setup>

import {nextTick} from 'vue';

const isData = ref(false);

// 图表的渲染函数
const echartInit = () => {
    if(chartRef.value){
        const myEchart = echarts.init(chartRef.value);
        // 配置项
        const option = {

           // 此处省略
        };
        
        myEchart.setOption(option);

        // 千万别忘了要resize
        myEchart.resize();        
          
    };
};

const changeButton = () => {

    isData.value = true;
    if(isData.value){
        nextTick(() => {
          // 图表的渲染函数,重新强制让它渲染一次
          echartInit();
        })
    }
    
}
</script>

重点:

  1. 在切换 v-show 的变量时,使用nextTick(() => {})函数 重新调用一次渲染echarts的函数echartInit

2.在渲染函数echartInit 里面要最后写一句resize !

相关推荐
smallLabel1 天前
记一次 OpenClaw 飞书插件接入填坑指南: Error: spawn EINVAL
前端
zzjyr1 天前
react前端项目 fetch原生 与 umijs request 四种请求区别
前端
我叫黑大帅1 天前
前端总说的防抖与节流到底是什么?
前端·javascript·面试
小时前端1 天前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
71Ove1 天前
告别手写字符串!UniApp 路由全自动类型生成工具
前端
掘金安东尼1 天前
从平面到空间:用 React Three Fiber 构建 3D 产品网格
前端·javascript·面试
小时前端1 天前
HTTPS 页面加载 HTTP 脚本被拦?同源代理来救场
前端·https
用户683709359551 天前
在 Rokid AR 眼镜里玩消消乐:基于 Unity 2022 LTS + UXR 3.0 SDK 的轻量级 AR 游戏尝试
前端
zzjyr1 天前
@umijs/max 中导出的 request 方法,如何实现 GET/POST/PUT/DELETE 这四种核心请求
前端
swipe1 天前
#用这 9 个浏览器 API,我把页面从“卡成 PPT”救回到 90+(每个都有能直接抄的例子)
前端·javascript·面试