• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Echarts整合(前后端、数据库)

武飞扬头像
码农桃子
帮助1

官方网站:https://echarts.apache.org/examples/zh/index.html

一、前端

0.安装echarts

npm install echarts --save

1.编写html

用来显示图表

```html

```

触发显示图标的按钮

html <el-button :disabled="btnDisabled" type="primary" icon="el-icon-search" @click="showChart()">查询</el-button>

2.引入echart

四版本

js import echarts from 'echarts'

五版本

js import * as echarts from 'echarts'

3.编写调用方法

编写方法getDataSta(),用来获取后端数据

学新通

js //用来获取后端数据 getDataSta(searchObj) { return request({ url: `/staservice/sta/showData/${searchObj.type}/${searchObj.begin}/${searchObj.end}`, method: 'get' }) }

4.编写js

showChart():用来获取后端传来的数据

其中格式必须为json数组格式

setChart()固定写法

一般只修改x,y轴数据就可以

```js methods:{ showChart() { staApi.getDataSta(this.searchObj) .then(response => { console.log('*****' response) this.yData = response.data.numDataList this.xData = response.data.date_calculatedList

  1.  
    //调用下面生成图表的方法,改变值
  2.  
    this.setChart()
  3.  
    })

}, setChart() { // 基于准备好的dom,初始化echarts实例 this.chart = echarts.init(document.getElementById('chart')) // console.log(this.chart)

  1.  
    // 指定图表的配置项和数据
  2.  
    var option = {
  3.  
    title: {
  4.  
    text: '数据统计'
  5.  
    },
  6.  
    tooltip: {
  7.  
    trigger: 'axis'
  8.  
    },
  9.  
    dataZoom: [{
  10.  
    show: true,
  11.  
    height: 30,
  12.  
    xAxisIndex: [
  13.  
    0
  14.  
    ],
  15.  
    bottom: 30,
  16.  
    start: 10,
  17.  
    end: 80,
  18.  
    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',
  19.  
    handleSize: '110%',
  20.  
    handleStyle: {
  21.  
    color: '#d3dee5'
  22.  
     
  23.  
    },
  24.  
    textStyle: {
  25.  
    color: '#fff'
  26.  
    },
  27.  
    borderColor: '#90979c'
  28.  
    },
  29.  
    {
  30.  
    type: 'inside',
  31.  
    show: true,
  32.  
    height: 15,
  33.  
    start: 1,
  34.  
    end: 35
  35.  
    }],
  36.  
    // x轴是类目轴(离散数据),必须通过data设置类目数据
  37.  
    xAxis: {
  38.  
    type: 'category',
  39.  
    data: this.xData
  40.  
    },
  41.  
    // y轴是数据轴(连续数据)
  42.  
    yAxis: {
  43.  
    type: 'value'
  44.  
    },
  45.  
    // 系列列表。每个系列通过 type 决定自己的图表类型
  46.  
    series: [{
  47.  
    // 系列中的数据内容数组
  48.  
    data: this.yData,
  49.  
    // 折线图
  50.  
    type: 'line'
  51.  
    }]
  52.  
    }
  53.  
     
  54.  
    this.chart.setOption(option)
学新通

} } ```

二、后端

1.控制层接受前端数据

java /** * 图表显示,返回日期和数量数组 * @param begin 开始日期 * @param end 结束日期 * @param type 查询类型 * @return */ @ApiOperation("图表显示,返回日期和数量数组") @GetMapping("showData/{type}/{begin}/{end}") public Result showData(@PathVariable String type, @PathVariable String begin, @PathVariable String end){ Map<String,Object> map = statisticsDailyService.getData(type,begin,end); return Result.ok().data(map); }

2.实现类的方法

获取数据库中的数据,

将结果封装在两个list中

日期list\ 数量list

java /** * 获取统计数据 * @param type 查询类型(注册、播放数量等) * @param begin 开始时间 * @param end 结束时间 * @return map */ @Override public Map<String, Object> getData(String type, String begin, String end) { QueryWrapper<StatisticsDaily> queryWrapper = new QueryWrapper<>(); //筛选日期 queryWrapper.between("date_calculated",begin,end); //精准查询日期和选择的类型 queryWrapper.select("date_calculated",type); List<StatisticsDaily> statisticsDailies = baseMapper.selectList(queryWrapper); //将结果封装在两个list中 //日期list List<String> dateCalculatedList = new ArrayList<>(); //数量list List<Integer> countList = new ArrayList<>(); for (StatisticsDaily daily : statisticsDailies) { dateCalculatedList.add(daily.getDateCalculated()); switch (type) { case "login_num": countList.add(daily.getLoginNum()); break; case "register_num": countList.add(daily.getRegisterNum()); break; case "video_view_num": countList.add(daily.getVideoViewNum()); break; case "course_num": countList.add(daily.getCourseNum()); break; default: break; } } HashMap<String, Object> map = new HashMap<>(); map.put("date_calculatedList",dateCalculatedList); map.put("numDataList",countList); return map; }

三、数据库

学新通

1.建表语句

sql CREATE TABLE `statistics_daily` ( `id` char(19) NOT NULL COMMENT '主键', `date_calculated` varchar(20) NOT NULL COMMENT '统计日期', `register_num` int(11) NOT NULL DEFAULT '0' COMMENT '注册人数', `login_num` int(11) NOT NULL DEFAULT '0' COMMENT '登录人数', `video_view_num` int(11) NOT NULL DEFAULT '0' COMMENT '每日播放视频数', `course_num` int(11) NOT NULL DEFAULT '0' COMMENT '每日新增课程数', `gmt_create` datetime NOT NULL COMMENT '创建时间', `gmt_modified` datetime NOT NULL COMMENT '更新时间', PRIMARY KEY (`id`), KEY `statistics_day` (`date_calculated`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='网站统计日数据';

2.记录来源

方法一:在控制层有可以主动调用的接口来查询注册人数等数据信息

方法二:在定时任务中可以每天定时调用service的方法来统计

学新通

定时任务

java @Componentpublic class ScheduleTask { @Autowired private StatisticsDailyService statisticsDailyService; /** * 定时任务 * 每天凌晨1点自动查询前一天的统计数据 */ @Scheduled(cron = "0 0 1 * * ?") public void updateStatisticsInfo() { //计算前一天日期 String preDay = DateUtil.formatDate(DateUtil.addDays(new Date(),-1)); statisticsDailyService.countRegister(preDay); }}

统计方法

java /** * 统计人数 * @param day 日期 */ @Transactional(rollbackFor = Exception.class) @Override public void countRegister(String day) { //防止重复添加,先删除 baseMapper.delete(new QueryWrapper<StatisticsDaily>().eq("date_calculated",day)); Result result = ucenterClient.countRegister(day); int countRegister = (int)result.getData().get("countRegister"); StatisticsDaily statisticsDaily = new StatisticsDaily(); //赋值统计的数据 statisticsDaily.setRegisterNum(countRegister); statisticsDaily.setDateCalculated(day); // TODO 随机数改为真实数据 statisticsDaily.setVideoViewNum( RandomUtils.nextInt(100,200)); statisticsDaily.setLoginNum(RandomUtils.nextInt(100,200)); statisticsDaily.setCourseNum(RandomUtils.nextInt(100,200)); //添加到数据库中 baseMapper.insert(statisticsDaily); }

四、实体数据

@TableField(fill = FieldFill.INSERT_UPDATE)注解 需要配置类

```java package com.gyb.staservice.entity;

import com.baomidou.mybatisplus.annotation.FieldFill; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProperty; import lombok.Data; import lombok.EqualsAndHashCode; import lombok.experimental.Accessors;

import java.io.Serializable; import java.util.Date;

/** *

* 网站统计日数据 *

* * @author 郜宇博 * @since 2021-10-27 */ @Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) @ApiModel(value="StatisticsDaily对象", description="网站统计日数据") public class StatisticsDaily implements Serializable {
  1.  
    private static final long serialVersionUID=1L;
  2.  
     
  3.  
    @ApiModelProperty(value = "主键")
  4.  
    @TableId(value = "id", type = IdType.ID_WORKER_STR)
  5.  
    private String id;
  6.  
     
  7.  
    @ApiModelProperty(value = "统计日期")
  8.  
    private String dateCalculated;
  9.  
     
  10.  
    @ApiModelProperty(value = "注册人数")
  11.  
    private Integer registerNum;
  12.  
     
  13.  
    @ApiModelProperty(value = "登录人数")
  14.  
    private Integer loginNum;
  15.  
     
  16.  
    @ApiModelProperty(value = "每日播放视频数")
  17.  
    private Integer videoViewNum;
  18.  
     
  19.  
    @ApiModelProperty(value = "每日新增课程数")
  20.  
    private Integer courseNum;
  21.  
     
  22.  
    @ApiModelProperty(value = "创建时间")
  23.  
    @TableField(fill = FieldFill.INSERT)
  24.  
    private Date gmtCreate;
  25.  
     
  26.  
    @ApiModelProperty(value = "更新时间")
  27.  
    @TableField(fill = FieldFill.INSERT_UPDATE)
  28.  
    private Date gmtModified;
学新通

} ```

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhghfghe
系列文章
更多 icon
同类精品
更多 icon
继续加载