vue2和vue3使用echarts时无数据,怎么显示暂无数据图片或文字

一开始也经历了用v-if和v-show,v-show的话echarts还会留出暂无数据图片的位置,导致echarts变形,v-if在加载和不加载切换时,dom会获取不到;后来也是在网上找的方法,时间有点长,原文地址就不贴了。

对了,在网上查方法的时候还找到了echarts noDataLoading这个方法,按照网上的写完,但是并没有起作用,不知道是方法移除了还是其他问题,后面实现了也没管它

vue2

echarts版本:4.9.0

默认你的echarts已经注册在全局,可以在组件中用this.$echarts()访问到(注册比较简单不细说)

html代码

<div id="mychart" style="width: 100%;height: 100%"></div>

script代码

import noData from '@/assets/nodata.png'

//ajax获取数据,判断数据为不为空,为空展示暂无数据,不为空则展示echarts

if(res.data.length){

this.initEcharts(res.data);

}else{

this.showNoData('mychart')

}

//暂无数据的方法

showNoData(id){

const noDataImg = noData // 暂无数据图片路径

const averageChart = document.getElementById(id)

averageChart.style.display = 'flex'

averageChart.style.flexDirection = 'column'

averageChart.style.justifyContent = 'center'

averageChart.style.alignItems = 'center'

if(averageChart.firstChild){

averageChart.innerHTML=''

}// 移除

const mainImg = document.createElement('img') // 添加要显示的图片

averageChart.appendChild(mainImg)

mainImg.style.width = 'auto'

mainImg.style.height = 'auto'

mainImg.src = noDataImg

const pBlock = document.createElement('p')//添加p标签

averageChart.appendChild(pBlock)

pBlock.innerHTML = '暂无数据' //我的图片里没有字,所以自己加了字,图片里有字可以把这里去掉或设为空

pBlock.style.color = '#2c3e50';

averageChart.removeAttribute('echarts_instance')

},

//渲染echarts

initEcharts(data){

let dom = document.getElementById("mychart");

let mychart = this.$echarts.getInstanceByDom(dom)

//注意一下这里,我的项目里可以选择时间,暂无数据图片和echarts来回切换,所以这里就要判断有没有echarts,因为在showNoData方法里有清除元素,不加的话会报错

if(mychart == null){

mychart = this.$echarts.init(dom)

}

//数据处理就不写了 最后把组好的option set进去就行了

mychart.setOption(你的option);

},

vue3

vue3我的使用场景跟vue2不太一样,3中没有时间选择框不需要切换echarts和图片(如有需要可以参考上面vue2的方法),echarts的数据是从父组件传过来的,所以要监听数组的变化(watch)并且dom也得存在(nextTick )

html代码

<div ref="bar" style="width: 100%; height: 100%"></div>

script setup代码

import noData from '../../../assets/nodata.png'

import { ref, watch, nextTick } from 'vue'

import * as echarts from 'echarts';

const props = defineProps({

data:{ type:Array, default:[]},

})

const bar = ref()

const initCharts = ()=>{

let barCharts = echarts.init(bar.value);

if(props.data.length){

barCharts.setOption(option)//用自己的option

}else{

showNoData(bar.value)

}

}

const showNoData = (ele) => {

const noDataImg = noData // 暂无数据图片路径

const averageChart = ele

averageChart.style.display = 'flex'

averageChart.style.flexDirection = 'column'

averageChart.style.justifyContent = 'center'

averageChart.style.alignItems = 'center'

if(averageChart.firstChild){

averageChart.innerHTML=''

}// 移除

const mainImg = document.createElement('img') // 添加要显示的图片

averageChart.appendChild(mainImg)

mainImg.style.width = '60px'

mainImg.style.height = '55px'

mainImg.src = noDataImg

const pBlock = document.createElement('p')//添加p标签

averageChart.appendChild(pBlock)

pBlock.innerHTML = ''

pBlock.style.color = '#2c3e50';

averageChart.removeAttribute('echarts_instance')

}

watch(

()=>props.data,

async(newValue)=>{

await nextTick()

initCharts()

},

{immediate:true,deep:true}

)

ok,到这里问题已解决