SpringBoot之Vue添加图表

SpringBoot之统计后台注册人数的图表

本文章只是提到这个工具的基本使用,并没有后端调用数据的方法,需要自己写

1.创建统计图表的数据库

2.后台需要查找截至前一天的统计数据,不是今天,然后加到上面这种表里面。所以设置定时任务,每天凌晨执行,下图是结构和一个工具类。工具类里面是查找前一天的日期

工具类DateUtil
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;

/**
 * 日期操作工具类
 *
 * @author qy
 * @since 1.0
 */
public class DateUtil {

    private static final String dateFormat = "yyyy-MM-dd";

    /**
     * 格式化日期
     *
     * @param date
     * @return
     */
    public static String formatDate(Date date) {
        SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
        return sdf.format(date);

    }

    /**
     * 在日期date上增加amount天 。
     *
     * @param date   处理的日期,非null
     * @param amount 要加的天数,可能为负数
     */
    public static Date addDays(Date date, int amount) {
        Calendar now =Calendar.getInstance();
        now.setTime(date);
        now.set(Calendar.DATE,now.get(Calendar.DATE)+amount);
        return now.getTime();
    }

    public static void main(String[] args) {
        System.out.println(DateUtil.formatDate(new Date()));
        System.out.println(DateUtil.formatDate(DateUtil.addDays(new Date(), -1)));
    }
}

定时器

定时器日期自动生成地址

import com.mine.guli.service.StatisticsDailyService;
import com.mine.guli.utils.DateUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

import java.util.Date;

//定时器
@Component
public class ScheduledTask {

    @Autowired
    private StatisticsDailyService staService;

    //在每天凌晨1点,把前一天的数据进行添加,执行方法,把数据查询进行添加
    @Scheduled(cron = "0 0 1 * * ?")
    public void task1(){
        staService.registerCount(DateUtil.formatDate(DateUtil.addDays(new Date(),-1)));
    }
    
}

3.Vue页面使用ECharts,下载依赖

官网地址

npm install --save echarts@4.1.0
4.整合页面
<template>
  <div class="app-container">
    <!--表单-->
    <el-form :inline="true" class="demo-form-inline">
      <el-form-item>
        <el-select v-model="searchObj.type" clearable placeholder="请选择">
          <el-option label="学员登录数统计" value="login_num"/>
          <el-option label="学员注册数统计" value="register_num"/>
          <el-option label="课程播放数统计" value="video_view_num"/>
          <el-option label="每日课程数统计" value="course_num"/>
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-date-picker
          v-model="searchObj.begin"
          type="date"
          placeholder="选择开始日期"
          value-format="yyyy-MM-dd" />
      </el-form-item>
      <el-form-item>
        <el-date-picker
          v-model="searchObj.end"
          type="date"
          placeholder="选择截止日期"
          value-format="yyyy-MM-dd" />
      </el-form-item>
      <el-button
        :disabled="btnDisabled"
        type="primary"
        icon="el-icon-search"
        @click="showChart()">查询</el-button>
    </el-form>
    <div class="chart-container">
      <div id="chart" class="chart" style="height:500px;width:100%" />
    </div>
  </div>
</template>

<script>
  import echarts from 'echarts'
  import staApi from '@/api/sta'
  export default {
      data() {
        return {
          searchObj: {
            type: '',
            begin: '',
            end: ''
          },
          btnDisabled: false,
          chart: null,
          title: '',
          xData: [],
          yData: []
        }
      },
      methods: {
        showChart() {
          this.initChartData()
          this.setChart()
        },
        // 准备图表数据
        initChartData() {
          staApi.getDataSta(this.searchObj).then(response =>{
            this.xData = response.data.date_calculated
            this.yData = response.data.numDataList
          })
        },
        // 设置图标参数
        setChart() {
          // 基于准备好的dom,初始化echarts实例
          this.chart = echarts.init(document.getElementById('chart'))
          // console.log(this.chart)
          // 指定图表的配置项和数据
          var option = {
            // 标题
            title: {
              text: '数据统计'
            },
            tooltip: {
              trigger: 'axis'
            },
            // 区域缩放,固定的
            dataZoom: [{
              show: true,
              height: 30,
              xAxisIndex: [
                0
              ],
              bottom: 30,
              start: 10,
              end: 80,
              handleIcon: 'path://M306.1,413c0,2.2-1.8,4-4,4h-59.8c-2.2,0-4-1.8-4-4V200.8c0-2.2,1.8-4,4-4h59.8c2.2,0,4,1.8,4,4V413z',
              handleSize: '110%',
              handleStyle: {
                color: '#d3dee5'
              },
              textStyle: {
                color: '#fff'
              },
              borderColor: '#90979c'
            },
              {
                type: 'inside',
                show: true,
                height: 15,
                start: 1,
                end: 35
              }],


            // x轴是类目轴(离散数据),必须通过data设置类目数据
            xAxis: {
              type: 'category',
              data: this.xData
            },
            // y轴是数据轴(连续数据)
            yAxis: {
              type: 'value'
            },
            // 系列列表。每个系列通过 type 决定自己的图表类型
            series: [{
              // 系列中的数据内容数组
              data: this.yData,
              // 折线图
              type: 'line'
            }]
          }
          this.chart.setOption(option)
        }
      }
  }
</script>

这里提供一个基于Spring Boot和Vue.js的动态统计图表例子。这个例子使用了ECharts图表库来绘制图表。 1. 在Spring Boot中,需要在pom.xml中添加以下依赖: ```xml <dependency> <groupId>org.webjars</groupId> <artifactId>echarts</artifactId> <version>4.9.0</version> </dependency> ``` 2. 在Vue.js中,需要在index.html中引入ECharts的js和css文件: ```html <!-- 引入 ECharts 的 JS 文件 --> <script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> <!-- 引入 ECharts 的 CSS 文件 --> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.css"> ``` 3. 在Vue.js中,需要在组件中定义一个div元素作为图表的容器,并在mounted()函数中使用ECharts初始化图表。例如: ```html <template> <div id="chart-container"></div> </template> <script> export default { mounted() { // 初始化 ECharts 实例 const chart = echarts.init(document.getElementById('chart-container')); // 指定图表的配置项和数据 const option = { title: { text: '动态统计图表', }, tooltip: {}, xAxis: { data: ['周一', '周二', '周三', '周四', '周五', '周六', '周日'], }, yAxis: {}, series: [ { name: '销量', type: 'bar', data: [5, 20, 36, 10, 10, 20, 30], }, ], }; // 使用刚指定的配置项和数据显示图表。 chart.setOption(option); }, }; </script> ``` 4. 在Spring Boot中,需要在Controller中提供一个接口,用于返回图表数据。例如: ```java @RestController @RequestMapping("/api") public class ChartController { @GetMapping("/chart-data") public Map<String, Object> getChartData() { Map<String, Object> data = new HashMap<>(); // 生成随机数据 int[] dataArray = new int[7]; Random random = new Random(); for (int i = 0; i < 7; i++) { dataArray[i] = random.nextInt(50); } // 将数据放入返回的Map中 data.put("xAxisData", new String[]{"周一", "周二", "周三", "周四", "周五", "周六", "周日"}); data.put("seriesData", dataArray); return data; } } ``` 5. 在Vue.js中,使用axios库来请求接口,并将返回的数据更新到图表中。例如: ```html <template> <div id="chart-container"></div> </template> <script> import axios from 'axios'; export default { mounted() { // 初始化 ECharts 实例 const chart = echarts.init(document.getElementById('chart-container')); // 使用 axios 请求接口获取数据 axios.get('/api/chart-data') .then(response => { // 从返回的数据中获取 x 轴和 y 轴的数据 const xAxisData = response.data.xAxisData; const seriesData = response.data.seriesData; // 指定图表的配置项和数据 const option = { title: { text: '动态统计图表', }, tooltip: {}, xAxis: { data: xAxisData, }, yAxis: {}, series: [ { name: '销量', type: 'bar', data: seriesData, }, ], }; // 使用刚指定的配置项和数据显示图表。 chart.setOption(option); }) .catch(error => { console.log(error); }); }, }; </script> ``` 这样,一个基于Spring Boot和Vue.js的动态统计图表就完成了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值