欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot整合Echarts實(shí)現(xiàn)用戶人數(shù)和性別展示功能(詳細(xì)步驟)

 更新時(shí)間:2023年05月08日 10:50:21   作者:FeereBug  
這篇文章主要介紹了SpringBoot整合Echarts實(shí)現(xiàn)用戶人數(shù)和性別展示,通過(guò)數(shù)據(jù)庫(kù)設(shè)計(jì)、實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)層、業(yè)務(wù)邏輯層和控制層的代碼編寫,以及前端頁(yè)面的開(kāi)發(fā),本文詳細(xì)地介紹了SpringBoot整合Echarts的實(shí)現(xiàn)步驟和代碼,需要的朋友可以參考下

一、背景

在Web應(yīng)用開(kāi)發(fā)中,經(jīng)常需要使用圖表來(lái)展示數(shù)據(jù),而Echarts是一個(gè)非常優(yōu)秀的圖表庫(kù)。SpringBoot是一個(gè)非常流行的Java Web框架,它可以快速搭建Web應(yīng)用。本文將介紹如何使用SpringBoot集成Echarts,實(shí)現(xiàn)展示用戶人數(shù)和性別的功能。

二、功能實(shí)現(xiàn)流程

1. 創(chuàng)建數(shù)據(jù)庫(kù)表

首先,我們需要?jiǎng)?chuàng)建數(shù)據(jù)庫(kù)表,用于存儲(chǔ)用戶信息。本文中,我們創(chuàng)建一個(gè)名為“user”的表,用于存儲(chǔ)用戶的id、姓名、性別等信息。

2. 創(chuàng)建SpringBoot項(xiàng)目

使用IDEA等工具,創(chuàng)建一個(gè)SpringBoot項(xiàng)目,并加入相應(yīng)的依賴。本文中,我們加入的主要依賴有SpringBoot、MyBatis、MySQL等。

3. 實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)層

使用MyBatis框架,實(shí)現(xiàn)對(duì)用戶信息的增刪改查等操作。同時(shí),我們也需要實(shí)現(xiàn)一個(gè)接口用于查詢用戶的性別比例。

4. 實(shí)現(xiàn)業(yè)務(wù)邏輯層

在業(yè)務(wù)邏輯層中,我們需要完成對(duì)應(yīng)的功能代碼。主要包括:添加用戶、刪除用戶、修改用戶信息、查詢所有用戶、查詢用戶性別比例等操作。其中,查詢用戶性別比例的操作需要使用Echarts來(lái)生成相應(yīng)的圖表。

5. 實(shí)現(xiàn)控制層

在控制層中,我們需要編寫對(duì)應(yīng)的接口,用于接收前端的請(qǐng)求,并調(diào)用相應(yīng)的業(yè)務(wù)邏輯層方法來(lái)完成相應(yīng)的操作。同時(shí),我們也需要編寫相應(yīng)的HTML頁(yè)面,用于展示用戶人數(shù)和性別比例的圖表。

6. 實(shí)現(xiàn)前端頁(yè)面

使用Vue框架,實(shí)現(xiàn)前端頁(yè)面,并通過(guò)接口調(diào)用,將后臺(tái)數(shù)據(jù)展示到前端頁(yè)面上。

三、代碼實(shí)現(xiàn)

本文提供一個(gè)示例代碼,代碼實(shí)現(xiàn)過(guò)程中,使用了SpringBoot、MyBatis、MySQL等主流技術(shù),實(shí)現(xiàn)了基本的增刪改查操作、以及查詢用戶性別比例并用Echarts展示的功能。示例代碼中的表名為“user”,根據(jù)實(shí)際情況可做相應(yīng)修改。

數(shù)據(jù)庫(kù)設(shè)計(jì)

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;

數(shù)據(jù)訪問(wèn)層代碼

@Mapper
@Component
public interface UserDao {
    int insert(User user);
    int delete(int userId);
    int update(User user);
    List<User> selectAll();
    int countByGender(int gender);
}

業(yè)務(wù)邏輯層代碼

@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();
    }
}

前端頁(yè)面代碼

<!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">
    <!-- 顯示用戶總數(shù) -->
    <p>共有{{ userList.length }}個(gè)用戶</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/>: {c} (vvxyksv9kd%)'
                },
                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>

四、總結(jié)

本文介紹了如何使用SpringBoot集成Echarts,實(shí)現(xiàn)展示用戶人數(shù)和性別的功能。通過(guò)數(shù)據(jù)庫(kù)設(shè)計(jì)、實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)層、業(yè)務(wù)邏輯層和控制層的代碼編寫,以及前端頁(yè)面的開(kāi)發(fā),本文詳細(xì)地介紹了SpringBoot整合Echarts的實(shí)現(xiàn)步驟和代碼。

其中,使用Vue框架進(jìn)行前端頁(yè)面開(kāi)發(fā),增加了Web應(yīng)用的可擴(kuò)展性和易用性。同時(shí),通過(guò)使用Echarts圖表庫(kù),我們可以讓數(shù)據(jù)呈現(xiàn)更為直觀清晰,增強(qiáng)用戶體驗(yàn)。

希望本文對(duì)讀者在Web應(yīng)用開(kāi)發(fā)中的圖表展示有所幫助。

到此這篇關(guān)于SpringBoot整合Echarts實(shí)現(xiàn)用戶人數(shù)和性別展示的文章就介紹到這了,更多相關(guān)SpringBoot整合Echarts內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Druid連接池未關(guān)閉導(dǎo)致內(nèi)存泄漏問(wèn)題

    Druid連接池未關(guān)閉導(dǎo)致內(nèi)存泄漏問(wèn)題

    這篇文章主要介紹了Druid連接池未關(guān)閉導(dǎo)致內(nèi)存泄漏問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 深入解析StringBuffer和StringBuilder的區(qū)別

    深入解析StringBuffer和StringBuilder的區(qū)別

    以下是對(duì)java中StringBuffer與StringBuilder的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以參考下
    2013-07-07
  • 關(guān)于Spring啟動(dòng)時(shí)Context加載源碼分析

    關(guān)于Spring啟動(dòng)時(shí)Context加載源碼分析

    這篇文章通過(guò)源碼分析主要給大家介紹了關(guān)于Spring啟動(dòng)時(shí)Context加載的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • Java LinkedList集合功能實(shí)例解析

    Java LinkedList集合功能實(shí)例解析

    這篇文章主要介紹了Java LinkedList集合功能實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 詳解Java實(shí)踐之適配器模式

    詳解Java實(shí)踐之適配器模式

    在計(jì)算機(jī)編程中,適配器模式(有時(shí)候也稱包裝樣式或者包裝)將一個(gè)類的接口適配成用戶所期待的。一個(gè)適配允許通常因?yàn)榻涌诓患嫒荻荒茉谝黄鸸ぷ鞯念惞ぷ髟谝黄穑龇ㄊ菍㈩愖约旱慕涌诎谝粋€(gè)已存在的類中
    2021-06-06
  • 聊聊Mybatis中sql語(yǔ)句不等于的表示

    聊聊Mybatis中sql語(yǔ)句不等于的表示

    這篇文章主要介紹了Mybatis中sql語(yǔ)句不等于的表示方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。
    2021-07-07
  • springboot擴(kuò)展MVC的方法

    springboot擴(kuò)展MVC的方法

    今天給大家?guī)?lái)的是關(guān)于Java的相關(guān)知識(shí),文章圍繞著springboot擴(kuò)展MVC的方法展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下
    2021-06-06
  • Java實(shí)現(xiàn)去掉字符串重復(fù)字母的方法示例

    Java實(shí)現(xiàn)去掉字符串重復(fù)字母的方法示例

    這篇文章主要介紹了Java實(shí)現(xiàn)去掉字符串重復(fù)字母的方法,涉及java針對(duì)字符串的遍歷、判斷、運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下
    2017-12-12
  • 詳解spring+springmvc+mybatis整合注解

    詳解spring+springmvc+mybatis整合注解

    本篇文章主要介紹了詳解spring+springmvc+mybatis整合注解,詳細(xì)的介紹了ssm框架的使用,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-04-04
  • Springboot使用POI實(shí)現(xiàn)導(dǎo)出Excel文件示例

    Springboot使用POI實(shí)現(xiàn)導(dǎo)出Excel文件示例

    本篇文章主要介紹了Springboot使用POI實(shí)現(xiàn)導(dǎo)出Excel文件示例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。
    2017-02-02

最新評(píng)論