SpringBoot整合Echarts实现用户人数和性别展示功能(详细步骤)
作者:FeereBug 发布时间:2023-02-22 00:31:59
一、背景
在Web应用开发中,经常需要使用图表来展示数据,而Echarts是一个非常优秀的图表库。SpringBoot是一个非常流行的Java Web框架,它可以快速搭建Web应用。本文将介绍如何使用SpringBoot集成Echarts,实现展示用户人数和性别的功能。
二、功能实现流程
1. 创建数据库表
首先,我们需要创建数据库表,用于存储用户信息。本文中,我们创建一个名为“user”的表,用于存储用户的id、姓名、性别等信息。
2. 创建SpringBoot项目
使用IDEA等工具,创建一个SpringBoot项目,并加入相应的依赖。本文中,我们加入的主要依赖有SpringBoot、MyBatis、MySQL等。
3. 实现数据访问层
使用MyBatis框架,实现对用户信息的增删改查等操作。同时,我们也需要实现一个接口用于查询用户的性别比例。
4. 实现业务逻辑层
在业务逻辑层中,我们需要完成对应的功能代码。主要包括:添加用户、删除用户、修改用户信息、查询所有用户、查询用户性别比例等操作。其中,查询用户性别比例的操作需要使用Echarts来生成相应的图表。
5. 实现控制层
在控制层中,我们需要编写对应的接口,用于接收前端的请求,并调用相应的业务逻辑层方法来完成相应的操作。同时,我们也需要编写相应的HTML页面,用于展示用户人数和性别比例的图表。
6. 实现前端页面
使用Vue框架,实现前端页面,并通过接口调用,将后台数据展示到前端页面上。
三、代码实现
本文提供一个示例代码,代码实现过程中,使用了SpringBoot、MyBatis、MySQL等主流技术,实现了基本的增删改查操作、以及查询用户性别比例并用Echarts展示的功能。示例代码中的表名为“user”,根据实际情况可做相应修改。
数据库设计
CREATE TABLE `user` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) NOT NULL,
`gender` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
数据访问层代码
@Mapper
@Component
public interface UserDao {
int insert(User user);
int delete(int userId);
int update(User user);
List<User> selectAll();
int countByGender(int gender);
}
业务逻辑层代码
@Mapper
@Component
public interface UserDao {
int insert(User user);
int delete(int userId);
int update(User user);
List<User> selectAll();
int countByGender(int gender);
}
控制层代码
@RestController
@RequestMapping("/users")
public class UserController {
@Autowired
private UserService userService;
@PostMapping("/add")
public String addUser(@RequestBody User user) {
userService.addUser(user);
return "success";
}
@PostMapping("/delete")
public String deleteUser(@RequestParam("userId") int userId) {
userService.deleteUser(userId);
return "success";
}
@PostMapping("/update")
public String updateUser(@RequestBody User user) {
userService.updateUser(user);
return "success";
}
@GetMapping("/all")
public List<User> getAllUsers() {
return userService.getAllUsers();
}
@GetMapping("/ratio")
public Map<String, Integer> getUserGenderRatio() {
return userService.getUserGenderRatio();
}
}
前端页面代码
<!DOCTYPE html>
<html>
<head>
<title>用户信息展示</title>
<meta charset="utf-8">
<!-- 引入Echarts -->
<script src="https://cdn.jsdelivr.net/npm/echarts@4.9.0/dist/echarts.min.js"></script>
<!-- 引入Vue -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<!-- 引入axios -->
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
</head>
<body>
<div id="app">
<!-- 显示用户总数 -->
<p>共有{{ userList.length }}个用户</p>
<!-- 显示用户性别比例 -->
<div id="genderRatio" style="width: 600px;height:400px;"></div>
</div>
<script>
new Vue({
el: '#app',
data: {
userList: []
},
mounted() {
this.getUserList();
this.showGenderRatio();
},
methods: {
getUserList() {
axios.get('/users/all')
.then(response => {
this.userList = response.data;
})
.catch(error => {
console.log(error);
})
},
showGenderRatio() {
axios.get('/users/ratio')
.then(response => {
let maleCount = response.data.male;
let femaleCount = response.data.female;
// 使用Echarts生成图表
let chart = echarts.init(document.getElementById('genderRatio'));
chart.setOption({
title: {
text: '用户性别比例',
subtext: '男性/女性'
},
tooltip: {
trigger: 'item',
formatter: '{a} <br/>{b}: {c} ({d}%)'
},
legend: {
orient: 'vertical',
left: 'left',
data: ['男性', '女性']
},
series: [
{
name: '性别',
type: 'pie',
radius: ['50%', '70%'],
avoidLabelOverlap: false,
label: {
show: false,
position: 'center'
},
emphasis: {
label: {
show: true,
fontSize: '30',
fontWeight: 'bold'
}
},
labelLine: {
show: false
},
data: [
{value: maleCount, name: '男性'},
{value: femaleCount, name: '女性'}
]
}
]
});
})
.catch(error => {
console.log(error);
})
}
}
});
</script>
</body>
</html>
四、总结
本文介绍了如何使用SpringBoot集成Echarts,实现展示用户人数和性别的功能。通过数据库设计、实现数据访问层、业务逻辑层和控制层的代码编写,以及前端页面的开发,本文详细地介绍了SpringBoot整合Echarts的实现步骤和代码。
其中,使用Vue框架进行前端页面开发,增加了Web应用的可扩展性和易用性。同时,通过使用Echarts图表库,我们可以让数据呈现更为直观清晰,增强用户体验。
希望本文对读者在Web应用开发中的图表展示有所帮助。
来源:https://blog.csdn.net/weixin_65950231/article/details/130539760


猜你喜欢
- 在互联网的服务端开发的时候,我们很经常要在一个项目中去调用不同的数据库。在这种情况下,必然要涉及到多数据源问题。那么,我们该如何解决多数据源
- FrameLayout(帧布局),LinearLayout (线性布局),AbsoluteLayout(绝对布局),RelativeLayo
- 下文笔者讲述java中String.intern()方法的功能简介说明,如下所示:String.intern原理String.intern(
- 1.封装分页Page类package com.framework.common.page.impl;import java.io.Seria
- 前段时间做了一个练手的小项目,名叫Book_Bar,用来卖书的,采用的是三层架构,也就是Models,IDAL,DAL,BLL 和 Web
- @Scheduled不执行的原因1. 今天用@Schedule做了一个定时任务希望凌晨1点执行,代码如下@Servicepublic cla
- // 十进制转化为十六进制,结果为C8。 Integer.toHexString(200); //十六进制转化为十进制,
- 背景今天学习Springboot,但是用的apache-maven 3.0 ,导入springboot1.5.19 ,Maven项目老是爆红
- 安装jdk1.7.0_04后,同时设置环境变量,并且source。可是java -version查看后,还是只能查看到jdk1.6和jdk1
- 为了追求更好的用户体验,有时候我们需要一个类似心跳一样跳动着的控件来吸引用户的注意力,这是一个小小的优化需求,但是在 Flutter 里动画
- java操作json对象出现StackOverflow错误今天在做项目的时候,遇到一个非常怪异的问题。一个java实体类中存在多个属性,每一
- 前言:干了这几个项目,也做过几次文件上传下载,要么是copy项目以前的代码,要么是百度的,虽然做出来了,但学习一下原理弄透彻还是很有必要的。
- 在开发过程中,不少有Spring Aop的使用,在面向切面编程时,我们会使用< aop:aspect>;在进行事务管理时,我们会
- producer是生产者的意思:指生产数据的线程,consumer是消费者的意思:指的是使用数据的线程public class Produc
- list.remove最近做项目的过程中,需要用到list.remove()方法,结果发现两个有趣的坑,经过分析后找到原因,记录一下跟大家分
- Android webview旋转屏幕导致页面重新加载问题解决办法1. 在create时候加个状态判断protected void onCr
- 本文实例为大家分享了android实现底部导航栏的具体代码,供大家参考,具体内容如下常见的底部导航栏动态效果实现步骤1.底部导航栏样式我们应
- 本文实例讲述了Java抛出异常与自定义异常类。分享给大家供大家参考,具体如下:异常处理常用方法:常用的异常处理方法有:一、try()catc
- 一、Maven项目使用步骤一般包含两步,1)引入依赖 2)特定的 IDE 引入对应的插件1)在POM中引入依赖<!-- https:/
- 本文实例讲述了C#使用linq查询大数据集的方法。分享给大家供大家参考。具体如下:using System;using System.Col