智慧社区管理系统08(维修和柱状图显现)

目录

后端代码

实体类

mapper层 

mappers sql语句  

Service层 

 接口

实现类 

Controller层 

前端部分

列表显示


后端代码

实体类

package com.woniu.community.entity;

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Bar {
    private Integer id;
    private String name;
    private Integer nums;
}

mapper层 

package com.woniu.community.mapper;

import com.woniu.community.entity.Bar;

import java.util.List;

public interface BarMapper {
    List<Bar> getBars();
}

mappers sql语句  

 这里是外表链接,查询出来的数据是这样的

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.woniu.community.mapper.BarMapper">

    <select id="getBars" resultType="Bar">
    select
    count(re.id) as nums,ret.name, ret.id
    from
        repairtype ret
    left join repair re on ret.id=re.com_id
    group by ret.id
    </select>
</mapper>

Service层 

 接口

package com.woniu.community.service;

import java.util.Map;

public interface IBarServic {
    Map getBars();
}

实现类 

 这次实现类我们这里使用的是HashMap封装之后,返回一个map集合

package com.woniu.community.service.Impl;

import com.woniu.community.entity.Bar;
import com.woniu.community.mapper.BarMapper;
import com.woniu.community.service.IBarServic;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
@Service
public class BarServiceImpl  implements IBarServic {
    @Autowired(required = false)
    private BarMapper barMapper;

    @Override
    public Map getBars() {
        List<Bar> bars = barMapper.getBars();
       // List<String> names = bars.stream().map(Bar::getName).collect(Collectors.toList());
        ArrayList<String> names = new ArrayList<>();
        bars.forEach(e->{
            names.add(e.getName());
        });
        List<Integer> nums=new ArrayList<>();
        bars.forEach(e->{
            nums.add(e.getNums());
        });
        HashMap map = new HashMap();
        map.put("names",names);
        map.put("nums",nums);
        return map;
    }
}

Controller层 

package com.woniu.community.controller;

import com.woniu.community.service.IBarServic;
import com.woniu.community.service.Impl.BarServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.Map;

@RestController
@RequestMapping("/bar")
@CrossOrigin(origins = "*")
public class BarController {
    @Autowired
    private BarServiceImpl barService;
    @RequestMapping("/list")
    public Map getBars() {
        return barService.getBars();
    }
}

浏览器访问地址,显示数据 

前端部分

列表显示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link href="assets/bootstrap-3.3.7-dist/css/bootstrap.min.css" rel="stylesheet">
    <link href="assets/css/right.css" rel="stylesheet">
    <script src="assets/jquery-3.5.1.min.js"></script>
    <script src="assets/bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
    <script src="assets/vue.min-v2.5.16.js"></script>
    <script src="assets/vue-router.min-2.7.0.js"></script>
    <script src="assets/axios.min.js"></script>
    <script src="assets/date_picker.js"></script>
    <script src="assets/echarts.min-5.4.0.js"></script>
</head>
<body>
<div id="app">
    <div id="bar" ref="bar" style="width: 1000px; height: 400px;">

    </div>
</div>
<script>
    new Vue({
        el: "#app",
        data: {
            xAxisdata: null,
            seisedata: null,
        },
        methods: {
            //请求数据
            getbarlist() {
                axios.get("http://localhost:8080/bar/list").then(response => {
                    console.log(response.data);
                    this.xAxisdata = response.data.names;
                    this.seriesdata = response.data.nums;
                    this.myechars();
                });
            },
            myechars() {
                var myecharts = echarts.init(this.$refs.bar);
                var option = {
                    xAxis: {
                        data: this.xAxisdata,
                    },
                    yAxis: {},
                    series: [
                        {
                            type: 'bar',
                            data: this.seriesdata,
                        }
                    ]
                };

                myecharts.setOption(option);
            }
        },
        mounted(){

        },
        created: function () {
            this.getbarlist();
        },
    });
</script>
</body>
</html>

这里我们先要导入文件, 

 

 此处div部分,app是命名vue,下方的 ref对应下图的代码

 这里数据就是通过getbarlist中的方法的axios获取数据,然后将数据传给myechars这个方法

myechars中的option中,将数据处理柱状图,然后将option设置到myechars中,之后getbarlist调用数据,最后在加载后调用getbarlist,然后var myecharts = echarts.init(this.$refs.bar);传入到div中

效果图显示如下

注意如果出现,内容显示不完全,就将div的widthheight设置合适的大小即可 


echars使用教程可以自行通过官网查看:

基础柱状图 - 柱状图 - 常用图表类型 - 应用篇 - Handbook - Apache ECharts

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值