JS每日一学:echarts图表无数据/空数据如何展示"暂无数据"。
我们从后端获取数据动态渲染图表时,难免会遇到数据为空的情况(虽然实际应用中这样的bug极少遇到),但考虑周全一点也好,看如何实现吧。
正常情况渲染图表:
<div id="test_chart" style="width: 600px;height:400px;"></div> <script> let chartData = [5, 20, 36, 10, 10, 20]; // 基于准备好的dom,初始化echarts实例 var myChart = echarts.init(document.getElementById('test_chart')); // 指定图表的配置项和数据 var option = { title: { text: 'ECharts 入门示例' }, tooltip: {}, legend: { data: ['销量'] }, xAxis: { data: ['衬衫', '羊毛衫'] }, yAxis: {}, series: [ { name: '销量', type: 'bar', data: chartData //动态数据 } ] }; // 使用刚指定的配置项和数据显示图表。 myChart.setOption(option); </script>
我们只需要:在定义option的外面加一个if条件判断,判断动态获取的数据是否有值,有则渲染图表,无则渲染指定内容——可以是暂无数据的图片,也可以是文字
1、显示“暂无数据”文字
<div id="test_chart" style="width: 600px;height:400px;"></div> <script> let chartData = [5, 20, 36, 10, 10, 20]; // 基于准备好的dom,初始化echarts实例 var myChart = echarts.init(document.getElementById('test_chart')); var option; // 指定图表的配置项和数据 if (chartData.length == 0 ) { //暂无数据 option = { title: { text: '暂无数据', x: 'center', y: 'center', textStyle: { fontSize: 14, fontWeight: 'normal', } } } } else { option = { title: { text: 'ECharts 入门示例' }, tooltip: {}, legend: { data: ['销量'] }, xAxis: { data: ['衬衫', '羊毛衫'] }, yAxis: {}, series: [ { name: '销量', type: 'bar', data: chartData //动态数据 } ] }; } // 使用刚指定的配置项和数据显示图表。 myChart.setOption(option); </script>
需要注意的是,如果有值的option里面没有定义title属性,那么就无法覆盖无值的情况渲染的“暂无数据”title,我们可以给它赋空值。
option = { title:{ text:'' }, xAxis:{}, yAxis:{}, series:{}, }
2、显示“暂无数据”图片
封装了一个noDataChart函数(可以直接复制使用),在上面的if判断为真的时候,调用这个函数,显示暂无数据图片即可。
// 暂无数据处理函数 noDataChart(dom){ //传入图表所在的dom节点 dom.removeChild(dom.firstChild) const mainImg = document.createElement('img') dom.appendChild(mainImg) // 定义要显示的图片 mainImg.style.width = 'auto' mainImg.style.height = 'auto' mainImg.src = noDataImg // 要显示图片的src路径,由外部统一定义,或直接写在这里也可以 const mainText = document.createElement('h3') //定义显示文字 dom.appendChild(mainText) dom.style.display = 'flex' dom.style.flexDirection = 'column' dom.style.justifyContent = 'center' dom.style.alignItems = 'center' mainText.innerHTML = '暂无数据' mainText.style.color = '#999999' dom.removeAttribute('_echarts_instance_') }, // 图表绘制函数 function myChartFunc(){ let dom = document.getElementById('test_chart') var myChart = echarts.getInstanceByDom(dom); //存在dom节点,获取已有的echarts实例的dom节点 if ( myChart == null ) { //不存在,进行初始化操作 myChart = echarts.init(dom); } // 指定图表的配置项和数据 if (chartData.length == 0 ) { //暂无数据 this.noDataChart(dom) //---调用暂无数据处理函数 } else { var option = { title: { text: 'ECharts 入门示例' }, /*图表相关配置*/ } myChart.setOption(option) } }
注意点:
1、noDataChart函数中使用的暂无数据图片noDataImg由外部定义,此处直接使用,可以根据需要选择外部定义或者是直接将图片路径写在对应位置;
2、在图表绘制函数内部,判断有无数据之前,新增了一条if语句,判断图表dom节点是否存在,存在则直接获取echarts实例,否则进行初始化操作;
3、因为在这种情况下,图表无数据时,我们没有使用到option变量,如果还是将option的声明写在if条件外侧(且myChart.setOption(option)也在外侧),那暂无数据的情况会导致setOption语句获取到option为undefined报错,所以直接将option的声明和定义、以及myChart.setOption(option)语句写在有数据的else代码块内部。
网友评论文明上网理性发言 已有0人参与
发表评论: