Vue3 echarts v-show无法重新渲染的问题

部分html代码如下

html 复制代码
<el-empty class="chart-small" v-if="!dataList || !dataList.length" description="没有数据"/>
<div class="chart-small" ref="dataBarDom" v-show="dataList && dataList.length">

部分js代码如下

这里需要引入nextTick方法

javascript 复制代码
import {ref, onMounted, reactive, nextTick} from "vue";


onMounted(async ()=>{
    getData()
})
// echarts相关
const dataBarDom = ref()//关联图标div的ref
let dataBar = null
// 需要显示的数据(有数据显示,没有数据不显示)
const dataList=ref([])
const getData=async ()=>{
    // 从后台获取需要渲染的数据
    dataList.value=await getDataFromDb()
    if(dataList.value.length){
        showChart.value=true
        nextTick(() => {
            dataBar= echarts.init(dataBarDom.value)
            //...以下省略渲染echart的代码
        })
    }else{
        showChart.value=false
    }
}

nextTick方法之后(Dom重新渲染)再去调用echarts图标的生成方法即可

相关推荐
遇见~未来8 分钟前
JavaScript数组全解析:从本质到高级技巧
开发语言·前端·javascript
石像鬼₧魂石12 分钟前
80 端口(Web 服务)渗透测试完整总结(含踩坑 + 绕过 + 实战流程)
linux·运维·服务器·前端·网络·阿里云
C_心欲无痕36 分钟前
nginx - 核心概念
运维·前端·nginx
开开心心_Every40 分钟前
安卓做菜APP:家常菜谱详细步骤无广简洁
服务器·前端·python·学习·edge·django·powerpoint
前端_Danny42 分钟前
用 ECharts markLine 实现节假日标注
前端·信息可视化·echarts
古城小栈43 分钟前
Rust 丰富&好用的 格式化语法
前端·算法·rust
丢,捞仔1 小时前
uni-app上架应用添加权限提示框
前端·javascript·uni-app
Glink1 小时前
从零开始编写自己的AI账单Agent
前端·agent·ai编程
Hilaku1 小时前
我是如何用一行 JS 代码,让你的浏览器内存瞬间崩溃的?
前端·javascript·node.js
努力犯错玩AI1 小时前
如何在ComfyUI中使用Qwen-Image-Layered GGUF:完整安装和使用指南
前端·人工智能