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,到这里问题已解决
vue2和vue3使用echarts时无数据,怎么显示暂无数据图片或文字的更多相关文章
- element el-tree、el-table组件加载数据前闪现 暂无数据 清除
相信很多人在使用element el-tree.el-table组件加载数据前会显示一个" 暂无数据 ",体验很不友好,有没有办法处理不显示呢?答案是:有的.废话不多说直接上代码 ...
- element table 先显示暂无数据 之后再加载数据 问题
项目中的表格请求数据时,进去页面,先出现 ''暂无数据'' 字样闪现一下之后在进行加载数据,用户体验十分不好 解决办法: <template> <el-table :data=&qu ...
- Repeater 控件 当数据源没有数据的时候显示 暂无数据 的两种方式
第一种:现在前台给Repeater控件外面的div加一个runat=”server” 然后在cs后台判断数据源是否为空, 是的话就修改这个前台div的InnerText或者是InnerHtml 即可 ...
- 如何解决在ie下,Echarts多次使用setOption更改数据时,数据错乱问题
一.问题描述 根据用户的操作,通过Ajax请求,获取某段时间内的某数据趋势折线图数据.用户切换数据项或更改时间段时,ie中渲染的折线图包含了上一次获取的数据,导致数据错乱,如下图所示: 二.代码 数据 ...
- Repeater在无数据记录时显示暂无数据
原文:Repeater在无数据记录时显示暂无数据 方法就是在FooterTemplate加个Label并根据repeater.Items.Count判断是否有记录.关键代码如下: <Footer ...
- easyUI draggable插件使用不当,导致拖动div内部文本框无法输入;设置echarts数据为空时就显示空白,不要动画和文字
先上一个Demo <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://ww ...
- Repeater为空时显示“暂无数据”,很方便实用方法
Repeater为空时显示“暂无数据”,很方便实用方法 <FooterTemplate> <asp:Label ID="lblEmptyZP" Text=&q ...
- echart大坑总结~~echarts呈现的数据刷新不完全/echarts画图时tooltip不会更新
谨以此文记录在使用echarts中遇到的各种大坑或者小坑,陆续更新加入新坑 欢迎朋友们一起提坑,我们势必绕过它们,愿我们永不再入坑~ 坑一:echarts图表重新赋值数据,图表显示会存在一部分原来的数 ...
- Vue2和Vue3技术整理1 - 入门篇 - 更新完毕
Vue2 0.前言 首先说明:要直接上手简单得很,看官网熟悉大概有哪些东西.怎么用的,然后简单练一下就可以做出程序来了,最多两天,无论Vue2还是Vue3,就都完全可以了,Vue3就是比Vue2多了一 ...
- vue2升级vue3指南(二)—— 语法warning&error篇
本文总结了vue2升级vue3可能会遇到的语法警告和错误,如果想知道怎样升级,可以查看我的上一篇文章:vue2升级vue3指南(一)-- 环境准备和构建篇 Warning 1.deep /deep/和 ...
随机推荐
- Scalpel:解构API复杂参数Fuzz的「手术刀」
Scalpel简介 Scalpel是一款自动化Web/API漏洞Fuzz引擎,该工具采用被动扫描的方式,通过流量中解析Web/API参数结构,对参数编码进行自动识别与解码,并基于树结构灵活控制注入位点 ...
- 简单了解一下国产GPU
英伟达都一万亿市值了,国产GPU现在发展的怎么样了?万字长文,有兴趣的进来简单了解一下. 最近,与GPU有关的几个科技新闻:一是英伟达NVIDIA市值超过一万亿美元,成为全球第一家市值过万亿的芯片公司 ...
- Windows11右键菜单修改为Win10模式的方法
Windows11右键菜单修改为Win10模式的方法 自述: 更新win11后看着鼠标右键的菜单有些不太舒服,索性就改回了win10的右键菜单的样式 , 下面开始进行操作 第一步 首先以管理员方式打开 ...
- [ARM 汇编]高级部分—性能优化与调试—3.4.3 使用模拟器进行调试与测试
在ARM汇编程序开发过程中,使用模拟器(emulator)进行调试和测试是一种非常有效的方法.模拟器可以在不同的处理器上测试代码,帮助我们发现潜在的问题,并提供丰富的调试功能.本节将介绍如何使用QEM ...
- 一文解开主流开源变更数据捕获技术之Flink CDC的入门使用
@ 目录 概述 定义 什么是CDC? CDC的分类 特性 应用场景 支持数据源 实战 Flink DataStream方式代码示例 FlinkSQL方式代码示例 概述 定义 flink-cdc-con ...
- LLaMA模型微调版本:斯坦福 Alpaca 详解
项目代码:https://github.com/tatsu-lab/stanford_alpaca 博客介绍:https://crfm.stanford.edu/2023/03/13/alpaca.h ...
- DevChat:将 GPT-4 无缝融入 VS Code,极致提升你的编程体验
目录 一.絮絮叨叨 1.1 缘起 1.2 嫌弃 1.3 征服 二.认真聊聊 2.1 老板给了少年一个任务 2.2 少年祭出了 DevChat 2.3 让 DevChat 帮着选 web 框架 2.4 ...
- Unity的OnOpenAsset:深入解析与实用案例
Unity OnOpenAsset 在Unity中,OnOpenAsset是一个非常有用的回调函数,它可以在用户双击资源文件时自动打开一个编辑器窗口.这个回调函数可以用于自定义资源编辑,提高工作效率. ...
- 【Vue】Echart图表
vue-echart-ui vue 集成 echart 图表的小 demo. 基础 series.type 包括:line(折线图).bar(条形图).pie(饼图).scatter(散点图).gra ...
- Oracle备份与还原(实用版)
Oracle备份与还原 EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用. I ...