集美大学 计算机 郑如滨

教学博客

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

引子

ECharts是百度出品的,一个使用JavaScript 实现的开源可视化库。程序员在Web页面上引入并稍作配置就能做出漂亮的数据图表。

本篇文章简单介绍一下如何在JSP中使用Echarts,例子图如下:

基本概念

图表显示是需要数据的,但是Echarts官网教程中为了演示方便直接在页面js中填入数据,如Demo-未来一周气温变化所示。“Mon、Tue..”等数据都直接在页面写好:

  xAxis: {
    type: 'category',
    boundaryGap: false,
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
  }

通常展示数据的页面需要动态的从远程服务器将数据取出放入图表。熟悉ajax的人,自然可以将上面的代码稍作修改实现动态取数据,这里尝试使用JSP来从服务器端获取数据。

示例

开发环境

  • Java 11
  • Tomcat 10
  • Eclipse JavaEE 2022版
  • jQuery 3.2
  • Echarts5

资源下载

代码:HTML页面

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<!-- 引入 ECharts 文件与jquery -->
<script src="js/echarts.min.js"></script>
<script src="js/jquery-3.2.1.js"></script>
<title>Echart5示例</title>
</head>
<body>

	<div>Echarts5示例</div>
	<!-- 为 ECharts 准备一个具备大小(宽高)的 DOM -->
	<div id="main" style="width: 600px; height: 400px;"></div>
	<script type="text/javascript">
		// 基于准备好的dom,初始化echarts实例
		//var myChart = echarts.init(document.getElementById('main'));
		var chartDom = document.getElementById('main');
		var myChart = echarts.init(chartDom);
		var url = 'GetAllDataServlet';//获得销量、营业额、x轴的数据
		$.getJSON(url).done(function(json) {//向url请求数据,如果成功,将数据放到json
			// 从json中获得数据
			salesVolume = json.salesVolume;//销量
			bussinessVolume = json.bussinessVolume;//营业额
			months = json.months;//月份

			// 配置option
			var option = {
				title : {
					text : '销量与营业额'
				},
				tooltip : {
					trigger : 'axis'
				},
				legend : {
					data : [ '销量' ],
					data : [ '营业额' ]
				},
				toolbox : {
					show : true,
					feature : {
						dataZoom : {
							yAxisIndex : 'none'
						},
						dataView : {
							readOnly : false
						},
						magicType : {
							type : [ 'line', 'bar' ]
						},
						restore : {},
						saveAsImage : {}
					}
				},
				xAxis : {
					type : 'category',
					data : months
				},
				yAxis : {
					type : 'value'
				},
				series : [ {
					name : '销量',
					type : 'bar',
					data : salesVolume
				}, {
					name : '营业额',
					type : 'line',
					data : bussinessVolume
				} ]

			}
			myChart.setOption(option);
		})
	</script>

</body>
</html>

这里的$.getJSON(url).done(function(json) ..使用了jQuery的ajax API,访问url指向的servlet,从servlet返回的数据放到json变量中。

代码:服务器端

@WebServlet("/GetAllDataServlet")
public class GetAllDataServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	public GetAllDataServlet() {
            super();
        }

	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		/*销量*/
		Integer[] salesVolume = {10,100,20,56,35,80};
		/*营业额*/
		double[] bussinessVolume = {10*10,100*8.5,20*9.5,56*9,35*9.5,80*9};
		/*横轴, 月份数据*/
		String[] months = {"1","2","3","4","5","6"};
		
		Map<String, Object> map = new HashMap<>();
		map.put("salesVolume", salesVolume);
		map.put("bussinessVolume",bussinessVolume);
		map.put("months", months);
		
		response.getWriter().println(JSON.toJSONString(map));
		
	}

	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}

这里使用了阿里开发的FastJson库将map中的值转换成Echarts可识别的json字符串,格式形如:

{"bussinessVolume":[100.0,850.0,190.0,504.0,332.5,720.0],"months":["1","2","3","4","5","6"],"salesVolume":[10,100,20,56,35,80]}

其他

  1. 实际上你也可以不用json工具,完全手写得到上述格式化字符串。
  2. 项目中使用了jQuery发起Ajax请求,你也可以使用其他框架,如Axios发起Ajax请求。

项目代码说明

  1. GetAllDataServlet.java,echarts5.html是前端通过Ajax访问Servlet获得echarts所需数据的完整示例。
  2. index.html里面包含了有用的参考链接。重点掌握其中使用jQuery实现ajax带参数请求,详见里面jQuery $.post() 方法

参考资料

posted on 2018-12-12 19:44  zhrb  阅读(1037)  评论(0编辑  收藏  举报