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图标的生成方法即可

相关推荐
阿赛工作室37 分钟前
AI时代WEB开发人员生存与发展报告
前端·人工智能·node.js
用户1257585243644 分钟前
写了三年定时任务还在手改 Cron 表达式?这个 GoFrame 后台框架帮你全闭环了
vue.js
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_36:(深入理解 Comment 接口与 DOM 注释节点)
前端·javascript·ui·html·音视频·视频编解码
石小石Orz1 小时前
Harness Engineering 到底是什么?概念、实战与争议,一次全部讲清楚
前端·后端
悠哉摸鱼大王1 小时前
cesium学习(三)-3d tiles
前端·cesium
前端那点事1 小时前
Vue3自定义Hooks保姆级教程!从原理到企业级实战,告别混乱代码
前端·vue.js
前端那点事1 小时前
别再乱用Vue3响应式!ref、reactive、toRef、toRefs完整区别+企业级落地实战
前端·vue.js
yingyima1 小时前
Base64 编码解码实战:业务场景下的高效应用
前端
閞杺哋笨小孩1 小时前
从脚手架到构建注入:Vue 多租户「入驻」工程实践
vue.js·vite
悠哉摸鱼大王1 小时前
cesium学习(五)-Primitive
前端·cesium