Echarts异步加载后端接口返回的Json数据生成图表

     一.Echarts 是一款很好用的前端报表制作工具,根据官网的开发文档,我们可以导入假数据制作各种分析的图表.详情看官网:Echarts官网案例.但是如果要根据实际情况导入真实的数据呢?怎么处理?

     操作的常规思路是这样的: 

     1.根据需要的业务逻辑编写后端接口,返回对应业务需求的JSON格式数据,具体参考本人之前的博文:SSM编写http接口返回JSON格式数据

     2.定义一个data为空的myChart,并赋值给对应的div显示

     3.定义对应数组,接收解析后的后台返回的JSON数据

     4.myChart.setOption方法中添加该数组

   二.源码

package com.ytdx.entity;

import java.io.Serializable;

public class EchartsEntity implements Serializable {
    private String name;
    private Integer num;
	public EchartsEntity(String name, Integer num) {
		super();
		this.name = name;
		this.num = num;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public Integer getNum() {
		return num;
	}
	public void setNum(Integer num) {
		this.num = num;
	}
    
}

package com.ytdx.action;

import java.util.ArrayList;
import java.util.List;


import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
import com.ytdx.entity.EchartsEntity;
import com.ytdx.util.JsonUtils;
import com.ytdx.util.ListObject;
import com.ytdx.util.ResponseUtils;
import com.ytdx.util.StatusCode;

@Controller
public class EchartsAction {

	@RequestMapping(value = "/Echarts")
	public void findById(HttpServletResponse response) {
		ListObject listObject = new ListObject();
		List<EchartsEntity> list = new ArrayList<EchartsEntity>();     //这里是后台添加假数据,可以改写成数据查询的方式
		list.add(new EchartsEntity("帽子",50));
		list.add(new EchartsEntity("鞋子",126));
		list.add(new EchartsEntity("毛衣",75));
		list.add(new EchartsEntity("羽绒服",201));
		list.add(new EchartsEntity("羊毛衫",172));
		listObject.setItems(list);
		listObject.setCode(StatusCode.CODE_SUCCESS);
		listObject.setMsg("成功");
		ResponseUtils.renderJson(response, JsonUtils.toJson(listObject));
	}
	
	@RequestMapping(value="/EchartsShow")
	public ModelAndView MyResource(ModelAndView mv) {
		mv.setViewName("/admin/Echarts");
		return mv;
	}
}

访问  http://localhost:8080/SnsSystem/Echarts ,获得返回的JSON数据


前端Ajax的get请求http://localhost:8080/SnsSystem/Echarts ,根据返回的状态码解析JSON数据,并赋值给定义好的对应数据

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>统计图表示例</title>
<script src="js/jquery-3.0.0.js"></script>
<script src="js/echarts.min.js"></script>
</head>
<body>
<!-- 为ECharts准备一个具备大小(宽高 -->
<div id="Main" style="width: 600px; height: 400px;border: 1px;"></div>

<script type="text/javascript">
var myChart = echarts.init(document.getElementById('Main'));
// 显示标题,图例和空的坐标轴
myChart.setOption({
	title : {
		text : '统计图表异步数据加载示例'
	},
	tooltip : {
		trigger: 'axis', //坐标轴触发提示框,多用于柱状、折线图中
	},
	legend : {     
		data : [ '销量' ]
	},
	toolbox: {
         feature: {
           dataView: {show: true, readOnly: false},
           magicType: {show: true, type: ['line', 'bar']},
           restore: {show: true},
           saveAsImage: {show: true}
         }
    },
	xAxis : {
		type : 'category',
		data : []
	},
	yAxis : {},
	series : [ {
		name : '销量',
		type : 'bar',
		data : []
	} ]
});

myChart.showLoading(); //数据加载完之前先显示一段简单的loading动画

var names = [];     //类别数组(实际用来盛放X轴坐标值)
var nums = [];       //销量数组(实际用来盛放Y坐标值)

$.ajax({
	type : "get",
	async : true, //异步请求(同步请求将会锁住浏览器,用户其他操作必须等待请求完成才可以执行)
	url : "${pageContext.request.contextPath }/Echarts", 
	dataType : "json", 
	success : function(data) {
		//请求成功时执行该函数内容,result即为服务器返回的json对象
		if (data.code == 'success') {       
			var obj = eval(data.items);     //解析后台传来的json数据
			for (var i = 0; i < obj.length; i++) {
				names.push(obj[i].name); 
			}
			for (var i = 0; i < obj.length; i++) {
				nums.push(obj[i].num);
			}
			myChart.hideLoading(); //隐藏加载动画
			myChart.setOption({ //加载数据图表
				xAxis : {
					data : names
				},
				series : [ {
					// 根据名字对应到相应的系列
					name : '销量',
					data : nums
				} ]
			});
		}else{
			alert("后台数据获取失败!");
		}
	},
	error : function(errorMsg) {
		//请求失败时执行该函数
		alert("图表请求数据失败!");
		myChart.hideLoading();
	}
})

 myChart.setOption(option);	
</script>
</body>
</html>

三.结果


  • 14
    点赞
  • 69
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
2020.04.02 F 修复 32 位系统无法编译小程序、提示重启耗时过久的问题 反馈详情 F 修复 使用 cli 打开 project.config.json 中 projectname 为中文的项目时会一直卡在初始化应用通信能力的问题 反馈详情 F 修复 ts 项目编译前命令无限执行的问题 反馈详情 F 修复 PC 端模拟器的 touchend 事件回调参数 changedTouches 为空的问题 反馈详情 2020.03.25 更新说明 A 新增 云开发控制台支持开通按量付费 A 新增 云开发支持数据库备份与回档(还原)详情 A 新增 支持小程序自动化多帐号调试 A 新增 显示灰度中的基础库以及基础库支持的客户端版本 详情 A 新增 下发测试基础库 详情 A 新增 支持模拟 API 的返回内容 详情 A 新增 支持同时重命名多个同名的文件 A 新增 真机调试出现异常时,可手动操作重试 A 新增 增加工具加载 loading 展示 A 新增 模拟器支持终止 A 新增 支持小游戏代码补全 U 优化 模拟器工具栏及状态栏界面 U 优化 云开发控制台监控图表展示 U 优化 模拟器添加边框 反馈详情 U 优化 更新命令行和 HTTP v2 版本 详情 F 修复 修改 cloudFunctionRoot 会出现文件找不到的问题 反馈详情 F 修复 不能正确打开已被删除文件夹的项目的问题 F 修复 点击菜单工具栏管理无反应的问题 F 修复 工具外修改项目配置 cli 上传不生效的问题 F 修复 工具预览/上传提示文件已经存在的问题 反馈详情 F 修复 调试器放大会导致 inspect 按钮样式异常的问题 F 修复 模拟器工具栏样式异常 F 修复 wx.addPhoneContact时顶部按钮显示错误的问题 反馈详情 F 修复 标题栏文字过长覆盖胶囊按钮的问题 F 修复 文件系统读取代码包内文件规则与真机不一致的问题 F 修复 关闭多帐号调试窗口 tabbar 内的 icon 无法加载的问题 反馈详情 F 修复 预览上传错误提示无效的 json 文件 反馈详情 F 修复 使用非等宽字体时光标可能错位的问题 F 修复 某些项目可能出现 wxml not found 的问题 F 修复 真机调试 Appdata 和 WXML 面板可能显示空白的问题 F 修复 弹出模拟器时 getMenuButtonBoundingClient 调用结果为空的问题 A 新增 支持小程序自动化截图功能 A 新增 编辑器面包屑导航条支持自定义快捷导航 A 新增 模拟小程序进程销毁重启 A 新增 编辑器行内错误和警告提示 A 新增 Mac 和 Windows 微信的模拟器类型 U 优化 1.02.1912261 的安装包结构 U 优化 MacOS 版关闭项目窗口时,显示项目列表窗口 U 优化 插件开发模式下 miniprogramRoot 下 app.json 中插件 provider 与项目 appid 一致时,version 必须为 "dev" F 修复 1.02.1912261 引入的多帐号调试 tabBar 图标无法加载的问题 F 修复 1.02.1912261 引入的 jsserverRoot 目录右键菜单缺失部分选项的问题 F 修复 公众号网页调试中,Base64 图片无法通过调试器打开的问题 反馈详情 F 修复 cli 调用自动预览无法使用自定义编辑条件的问题 F 修复 Windows 版无法使用录音功能的问题 F 修复 插件开发模式下,插件页面配置不生效的问题 F 修复 小游戏开放数据域使用增强编译报错的问题 F 修复 Windows 版某些情况下无法显示项目窗口的问题 F 修复 切换 cloudfunctionsRoot 无法同步云函数的问题 反馈详情 F 修复 Wxml 面板丢失 text 标签子节点的问题 F 修复 上传时文件体积大小提示错误问题 反馈详情 F 修复 使用非等宽字体时光标可能错位的问题 F 修复 文件系统 api 读取代码包内文件规则与真机不一致的问题 A 新增 编辑器全局替换 A 新增 编辑器分栏 A 新增 编辑器文件多选操作和拖动到文件夹 A 新增 编辑器多选操作和拖动到文件夹 A 新增 编辑器代码大纲 A 新增 编辑器文件对比 A 新增 选取 android 设备上的 profile 文件进行分析 详情 A 新增 WXML 面板支持自定义组件数据查看与实时修改 A 新增 WXML 面板支持使用键盘 (上下左右) navigate the DOM tree A 新增 WXML 面板
ECharts 是一款基于 JavaScript 的可视化图表库,可以通过 AJAX 异步请求后端数据并将数据绑定到柱状图上展示。以下是一个使用 jQuery 和 AJAX 请求后端数据并绑定到 ECharts 柱状图的示例: HTML 代码: ```html <div id="echarts" style="width: 600px;height:400px;"></div> ``` JavaScript 代码: ```javascript // 引入 ECharts var echarts = require('echarts'); // 初始化 ECharts 实例 var myChart = echarts.init(document.getElementById('echarts')); // 发送 AJAX 请求后端数据 $.ajax({ type: 'GET', url: '/data', // 后端接口地址 dataType: 'json', success: function (data) { // 处理后端返回数据并绑定到柱状图上 myChart.setOption({ title: { text: '柱状图示例' }, tooltip: {}, legend: { data:['销量'] }, xAxis: { data: data.categories // 后端返回的横坐标数据 }, yAxis: {}, series: [{ name: '销量', type: 'bar', data: data.series // 后端返回的纵坐标数据 }] }); }, error: function (xhr, textStatus, errorThrown) { console.log('AJAX 请求失败:' + xhr.status + ', ' + errorThrown); } }); ``` 后端代码示例(使用 Node.js 和 Express 框架): ```javascript const express = require('express'); const app = express(); // 处理 AJAX 请求 app.get('/data', function (req, res) { const data = { categories: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'], // 横坐标数据 series: [5, 20, 36, 10, 10, 20, 10] // 纵坐标数据 }; res.send(data); }); // 启动服务器 app.listen(3000, function () { console.log('服务器启动成功:http://localhost:3000/'); }); ``` 以上示例中,后端代码返回了一个 JSON 格式的数据,包含横坐标和纵坐标数据。前端使用 AJAX 发送 GET 请求获取数据,并将数据绑定到 ECharts 实例上,最终展示在页面上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潇潇雨歇_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值