SpringBoot+Vue+Echarts+MySQL

这是一篇介绍前后台项目如何使用前台Vue,后台SpringBoot,数据库MySQL如何整合Echarts,并实现真实数据的展现的博客,我用的是最简单的饼图,柱状图,折线图。

1.静态Echarts 

 引入echarts

1.前台控制台安装echarts  

npm install echarts --save

2.项目引入echarts

<script> 中写入

import * as echarts from 'echarts';

使用示例代码

1.找完整代码

 echars官网【Examples - Apache ECharts

进入【所有示例】- 点击图像 - 即可进入代码展示

【完整代码】

2.改编代码

2.1 <template>中写<div>用来装图,并给出一个宽度和高度、id

<template> 
   <div style="flex: 1; margin-top: 50px">
      <div id="pie" style="width: 100%; height: 400px"></div>
   </div>
</template>

2.2<script> 中引入

import * as echarts from 'echarts';

2.3<script>中写函数来初始化图

<script>
import * as echarts from 'echarts';

export default {
  name: 'HomeView',
  
  data(){
    return{
      data:[] 
    };
  },

  mounted () {
    this.initPie(); //一定要记得调用,不然显示不出来
  },

  methods: {
    initPie(data) {
      var chartDom = document.getElementById('pie');
      var myChart = echarts.init(chartDom);
      var option;

      option = {
        title: {
          text: 'Subject',
          subtext: 'real data',
          left: 'center'
        },
        tooltip: {
          trigger: 'item'
        },
        legend: {
          orient: 'vertical',
          left: 'left'
        },
        series: [
          {
            name: 'Subject',
            type: 'pie',
            radius: '50%',
            data: [
              { value: 1048, name: 'Search Engine' },
              { value: 735, name: 'Direct' },
              { value: 580, name: 'Email' },
              { value: 484, name: 'Union Ads' },
              { value: 300, name: 'Video Ads' }  // //这里是复制来的假数据
            ],
            emphasis: {
              itemStyle: {
                shadowBlur: 10,
                shadowOffsetX: 0,
                shadowColor: 'rgba(0, 0, 0, 0.5)'
              }
            }
          }
        ],
      };

     
      option && myChart.setOption(option); //最关键的设置图步骤
 
    },
      
  }
}
</script>

注意点:

a.一定要给一个div设置图的宽高和id

b.记得引入

c.要写函数装初始化图的代码,其中调用div的id记得改

d.mounted记得调用初始化图的函数

2.后台连接数据库

1.准备工作

确保application.yml配置了mysql数据库

确保数据库创建了名为echarts的自增表

确保pom.yml的依赖都下好了(MyBatis什么的)

2.正式写代码

这份代码没有用到service层

controller->dao   entity->table(echarts)

EchartsController.java

package com.example.controller;

import com.example.dao.EchartsDao;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;

@CrossOrigin
@RestController
@RequestMapping("/echarts")
public class EchartsController {

    @Resource
    private EchartsDao echartsDao;
    //有点不一样 直接从controller调用到dao

    @GetMapping("/pie")
    public Object pie(){

        return echartsDao.selectAll();
        //查询所有数据
    }

    @GetMapping("/bar")
    public Object bar(){

        return echartsDao.selectAll();
        //查询所有数据
    }

    @GetMapping("/line")
    public Object line(){

        return echartsDao.selectAll();
        //查询所有数据
    }



}

Echarts.java实体类

package com.example.entity;

import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;

import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import java.util.Date;

@Data
@Table(name = "echarts")
public class Echarts {

    @Id  //自增主键标记
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    private String name;
    private Integer count;   //和数据库对应

    @JsonFormat(pattern = "yyyy-MM-DD" , timezone = "GMT+8")//日期格式化 +  时区东八区
    private Date date;


}

 EchartsDao.java接口类持久层

package com.example.dao;

import com.example.entity.Echarts;
import org.springframework.stereotype.Repository;
import tk.mybatis.mapper.common.Mapper;


@Repository
public interface EchartsDao extends Mapper<Echarts> {

}

注意点:

a.路径api,路由守卫记得放行

b.不要忘记数据库主键自增

3.前台接口

饼图:

 fetch("http://localhost:8080/api/echarts/pie").then(response => response.json()).then(res => {
        res.forEach(item => {
          option.series[0].data.push({name : item.name , value : item.count})  //数组插入数据库数据
        });
        
        option && myChart.setOption(option); //最关键的设置图步骤 将原始代码的这句移入fetch中
        
        // console.log(option)  用来检验的打印步骤
      })

折线图:

  fetch("http://localhost:8080/api/echarts/line").then(response => response.json()).then(res => {
        //循环开始前先处理x轴数据
        const date = res.map( v => v.date);
        console.log(date) ;// 打印数据库中每行数据的date数组
        option.xAxis.data = date;

        //设置y轴
        const count = res.map( v => v.count);
        console.log(count) ;// 打印数据库中每行数据count数组
        option.series[0].data = count;
        
        option && myChart.setOption(option); //最关键的设置图步骤 将原始代码的这句移入fetch中
      })

 柱状图:

fetch("http://localhost:8080/api/echarts/bar").then(response => response.json()).then(res => {
        //循环开始前先处理x轴数据
        const date = res.map( v => v.date);
        console.log(date) ;// 打印数据库中每行数据的date数组
        option.xAxis.data = date;

        //设置y轴
        const count = res.map( v => v.count);
        console.log(count) ;// 打印数据库中每行数据count数组
        option.series[0].data = count;
        
        option && myChart.setOption(option); //最关键的设置图步骤 将原始代码的这句移入fetch中
      })

注意点:

d.记得把原始假数据删掉

a.上述fetch代码加在各自的初始化函数中

b.【option && myChart.setOption(option);】这行代码是从原初始化函数中移入fetch中的!!

c.线图和柱状图要设置x、y轴,逻辑类似,饼图逻辑简单

4.成功!

  • 21
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
# 项目特点 - 前台参考"Hexo"的"Butterfly"设计,美观简洁,响应式体验好。 - 后台参考"element-admin"设计,侧边栏,历史标签,面包屑自动生成。 - 采用Markdown编辑器,写法简单。 - 评论支持表情、GIF动图输入回复等,样式参考Valine。 - 前后端分离部署,适应当前潮流。 - 接入第三方登录,减少注册成本。 - 留言采用弹幕墙,更加炫酷。 - 支持代码高亮和复制,图片预览,深色模式等功能,提升用户体验。 - 搜索文章支持高亮分词,响应速度快。 - 新增文章目录、推荐文章等功能,优化用户体验。 - 新增在线聊天室,支持撤回、语音输入、统计未读数量等功能。 - 新增aop注解实现操作日志功能。 - 支持动态权限修改,采用RBAC模型,前端菜单和后台权限实时更新。 - 后台管理支持修改背景图片,博客配置等信息,操作简单,支持上传相册。 - 代码支持多种搜索模式(Elasticsearch或MYSQL),支持多种上传模式(OSS或本地),可支持配置。Elasticsearch占内存较高,如果服务器配置太低,不建议使用。 - 新增网站导航功能,页面优雅美观。可自行添加自己常用的网站进行分类和排序。 - 新增聊天管理功能,方便清理垃圾聊天内容。 - 新增登录日志功能,随时查看用户的登录信息。 - 前台页面重新布局重构,页面布局更加简洁,首页加载速度更快。 - 前台首页文章列表顶部新增滚动消息,超级炫酷。 - 新增了监控用户是否授权的功能、增加了用户的体验性。 - 增加图片删除后也将该路径的图片删除的功能、大大提高了文件存储的利用率。 - 将接口进行**axios**二次封装、更利于接口的请求和响应。 - 新增本博客配套的**微信小程序**,可随时用手机浏览文章。并且接入微信登录,减少注册成本。 - **微信小程序**新增每日新闻热搜功能、可随时查看热搜。 - 新增本博客配套的**App**,同时接入qq、微博登录,使用更加方便。 - 代码遵循阿里巴巴开发规范,利于开发者学习。 ## 技术介绍 **前端:** vue + vuex + vue-router + axios + vuetify + element + echarts + uniapp + uview + Html + Css + JavaScript **后端:** SpringBoot + nginx + docker + SpringSecurity + Swagger2 + MyBatisPlus + Mysql + Redis + elasticsearch + RabbitMQ + MaxWell + Websocket **其他:** 接入QQ,微博、微信第三方登录,接入腾讯云人机验证、websocket ## 运行环境 ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
Spring Boot是一个基于Spring框架的快速开发Web应用程序的框架,Vue是一种流行的JavaScript框架,用于构建用户界面,MySQL是一种流行的关系型数据库,Echarts是一个基于JavaScript的图表库,用于可视化数据。结合这些技术可以构建一个功能强大的Web应用程序,以下是一个简单的演示: 1.后端使用Spring Boot和Mybatis Plus连接MySQL数据库,提供API接口供前端调用,以下是一个简单的示例代码: ```java @RestController @RequestMapping("/api") public class DataController { @Autowired private DataService dataService; @GetMapping("/data") public List<Data> getData() { return dataService.getData(); } } ``` 2.前端使用Vue和Element-UI构建用户界面,使用Echarts可视化数据,以下是一个简单的示例代码: ```vue <template> <div> <el-table :data="tableData"> <el-table-column prop="name" label="名称"></el-table-column> <el-table-column prop="value" label="值"></el-table-column> </el-table> <div ref="chart" style="height: 400px;"></div> </div> </template> <script> import axios from 'axios' import echarts from 'echarts' export default { data() { return { tableData: [] } }, mounted() { axios.get('/api/data').then(response => { this.tableData = response.data this.renderChart() }) }, methods: { renderChart() { const chart = echarts.init(this.$refs.chart) const data = this.tableData.map(item => ({ name: item.name, value: item.value })) chart.setOption({ title: { text: '数据可视化' }, tooltip: {}, xAxis: { data: data.map(item => item.name) }, yAxis: {}, series: [{ name: '值', type: 'bar', data: data.map(item => item.value) }] }) } } } </script> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值