成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Springboot運用vue+echarts前后端交互實現動態圓環圖

瀏覽:4日期:2023-03-04 16:36:59
目錄前言一、環境配置1.1 安裝acharts1.2 全局引用二、圓環圖前端實現2.1 先在vue頁面添加渲染盒子2.2 前端邏輯實現部分2.3 展示(可按自己需求更改前端樣式)三、前后端數據交互實現3.1 創建數據庫3.2 后臺代碼的編寫前言

我們做項目的時候,常常需要一些統計圖來展示我們的數據,作為web開發人員,會實現統計圖是我們必會的技能。我將帶大家來實現動態餅圖的實現

一、環境配置1.1 安裝acharts

//npm也一樣cnpm install echarts --save1.2 全局引用

main.js中配置

//引入 echartsimport echarts from ’echarts’//注冊組件Vue.prototype.$echarts = echarts

全局注冊好組件之后就讓我們進入正題吧,第一步先繪制圓環圖吧。先上結果圖:

Springboot運用vue+echarts前后端交互實現動態圓環圖

二、圓環圖前端實現2.1 先在vue頁面添加渲染盒子

<template> <div style='width:600px;height:400px;'> <div style='width:100%;height:278px;float:left;'></div> </div></template>2.2 前端邏輯實現部分

引入echart

import * as echarts from ’echarts’

注意:這里有一個大坑,如果你安裝的是高版本的echarts,一定要按我這個來,import echarts from ’echarts’網上很多人都這么分享會發生init函數初始化錯誤

<script> import * as echarts from ’echarts’ export default { name: ’test2’, data () { return { queryInfo: { query: '', pageNum: 1, pageSize: 4,//后端請求的數據類別4個,如果你有多個,就更改這個參數 }, queryInfof: { query: '', pageNum: 1, pageSize: 100, }, myChart: ’’, opinionData2: [ {'itemStyle':'#3F8FFF','name':'威脅攻擊日志','value':200}, {'itemStyle':'#6DC8EC','name':'審計url異常','value':388}, {'itemStyle':'#1FC48D','name':'正常網絡日志','value':5287}, {'itemStyle':'red','name':'流量日志異常','value':320} ] } }, mounted: function () { this.drawLine(); }, methods: { async drawLine () { // 調用post請求 /* const { data: res } = await this.$http.get('alldate', {params: this.queryInfo }); if (res.flag != 'success') {return this.$message.error('該數據獲取失敗!!!'); } console.log(res.flag) this.opinionData2 = res.opinionData2; // 將返回數據賦值*/ this.myChart = echarts.init(document.getElementById(’myChart’)) this.myChart.setOption({ title: { text: ’網絡日志異常流量分析’, // 主標題 subtext: ’’, // 副標題 x: ’left’ // x軸方向對齊方式 }, grid: { containLabel: true }, tooltip: { trigger: ’item’, formatter: ’{a} <br/>{b} : tfvdlnb%’ }, // color: [’#1FC48D’, ’#F5A60A’, ’#6DC8EC’, ’#3F8FFF’], color: [’#1FC48D’, ’red’, ’#6DC8EC’, ’#3F8FFF’], // backgroundColor: ’#ffffff’, legend: { orient: ’vertical’, icon: ’circle’, align: ’left’, x: ’right’, y: ’bottom’, data: [’審計url異常’, ’正常網絡日志’, ’流量日志異常’, ’威脅攻擊日志’] }, series: [ { name: ’網絡日志狀態’, type: ’pie’, radius: [’50%’, ’70%’], avoidLabelOverlap: false, center: [’40%’, ’50%’], itemStyle: { emphasis: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: ’rgba(0, 0, 0, 0.5)’ }, color: function (params) { // 自定義顏色 var colorList = [’#1FC48D’, ’red’, ’#6DC8EC’, ’#3F8FFF’] return colorList[params.dataIndex] } }, data: this.opinionData2 } ] }) }, } } </script>2.3 展示(可按自己需求更改前端樣式)

Springboot運用vue+echarts前后端交互實現動態圓環圖

三、前后端數據交互實現3.1 創建數據庫

表結構:(根據你的業務需要創建)

Springboot運用vue+echarts前后端交互實現動態圓環圖

表數據

Springboot運用vue+echarts前后端交互實現動態圓環圖

3.2 后臺代碼的編寫

3.2.1 在bean包下創建QueryInfo類

該類實現得到前端請求的數據條數。相當于分頁功能。

public class QueryInfo { private String query; private int pageNum=1; private int pageSize=1; public QueryInfo() { } public QueryInfo(String query, int pageNum, int pageSize) {this.query = query;this.pageNum = pageNum;this.pageSize = pageSize; } public String getQuery() {return query; } public int getPageNum() {return pageNum; } public int getPageSize() {return pageSize; } public void setQuery(String query) {this.query = query; } public void setPageNum(int pageNum) {this.pageNum = pageNum; } public void setPageSize(int pageSize) {this.pageSize = pageSize; } @Override public String toString() {return 'QueryInfo{' +'query=’' + query + ’’’ +', pageNum=' + pageNum +', pageSize=' + pageSize +’}’; }}

3.2.2 在bean包下創建Showdate類

public class Showdate { private String name; private String itemStyle; private int value; public Showdate() { } public Showdate(String name, String itemStyle, int value) {this.name = name;this.itemStyle = itemStyle;this.value = value; } public String getName() {return name; } public void setName1(String name) {this.name= name; } public String getItemStyle() {return itemStyle; } public void setItemStyle(String itemStyle) {this.itemStyle = itemStyle; } public int getValue() {return value; } public void setValue(int value) {this.value = value; } @Override public String toString() {return 'Showdate{' +'name=’' + name + ’’’ +', itemStyle=’' + itemStyle + ’’’ +', value=' + value +’}’; }}

3.2.3 在resources下創建Mapper

1.在Mapper中創建ShowDataMapper.xml

<?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.naughty.userlogin02.dao.ShowdateDao'> <select resultType='com.naughty.userlogin02.bean.Showdate'>SELECT * FROM date1<if test='name!=null '> WHERE name like #{name}</if>LIMIT #{pageStart},#{pageSize} </select> <update id='updatenew'>UPDATE date1 SET value = #{count} WHERE name = #{name} </update></mapper>

2.在resources下創建application.yml用于配置數據庫和端口號

# mysqlspring: datasource: #MySQL配置 driverClassName: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/weblog?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC username: root password: rootmybatis: mapper-locations: classpath:mapper/*.xml type-aliases-package: com.example.demo.modelserver: port: 9000

3.2.4 在Dao下創建ShowdateDao

里面有兩個接口,如果你需要操作數據庫,就需要在ShowdateDao中編寫接口方法;在ShowDataMapper.xml中編寫sql語句。我這里實現了修改和查找;

import com.naughty.userlogin02.bean.Showdate;import org.apache.ibatis.annotations.Param;import org.springframework.stereotype.Repository;import java.util.List;@Repositorypublic interface ShowdateDao { public List<Showdate> getAlldate(@Param('name') String name, @Param('pageStart') int pageStart, @Param('pageSize') int pageSize); public int updatenew(String name, int count);}

3.2.5 在Controller下創建ShowdateController

在ShowdateController中要注解使用空間

@Autowired ShowdateDao showdateDao;//你需要傳給前端的數據庫表 @Autowired FlowDao flowDao;//你的數據來源的效果數據庫表

package com.naughty.userlogin02.controller;import com.alibaba.fastjson.JSON;import com.naughty.userlogin02.bean.*;import com.naughty.userlogin02.dao.CheckDao;import com.naughty.userlogin02.dao.FlowDao;import com.naughty.userlogin02.dao.SafeDao;import com.naughty.userlogin02.dao.ShowdateDao;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.web.bind.annotation.*;import java.util.HashMap;import java.util.List;import java.util.Stack;@RestControllerpublic class ShowdateController { @Autowired ShowdateDao showdateDao; @Autowired FlowDao flowDao;//前臺刷新日志數據 @CrossOrigin @RequestMapping('/alldate')//前端請求通道 public String getAlldateList(QueryInfo queryInfo){System.out.println(queryInfo);int pageStart = (queryInfo.getPageNum()-1)*queryInfo.getPageSize();List<Showdate> dates = showdateDao.getAlldate('%'+queryInfo.getQuery()+'%',pageStart,queryInfo.getPageSize()); for(int i =0;i<dates.size();i++){ System.out.println(dates.get(i).toString()); }//校驗//封裝校驗后的流量日志HashMap<String, Object> res = new HashMap<>();res.put('flag','success');res.put('opinionData2',dates );String date_json= JSON.toJSONString(res);System.out.println(date_json.toString());return date_json; }//數據庫數據來源的實現方法,就是改變數據庫表Date1中得數據 @RequestMapping('/getupdata') public String updateDate(QueryInfo queryInfo){String s = '流量日志異常';String s1 ='審計url異常';String s2 ='威脅攻擊日志';String s3 ='正常網絡日志';/*int count = getUserList(queryInfo);int count1 =getChickList(queryInfo); //四個方法需要你自己根據具體業務實現int count2 =getSafeDate(queryInfo);int count3 =allBlognum(queryInfo)-(count+count1+count2);*/showdateDao.updatenew(s,count);showdateDao.updatenew(s1,count1);showdateDao.updatenew(s2,count2);int i= showdateDao.updatenew(s3,count3);System.out.println('異常類型:'+s);System.out.println('異常日志數量:'+count);String str = i >0?'success':'error';return str; }}

3.2.6 修改前端接口

Js全部代碼:

<script> import * as echarts from ’echarts’ export default { name: ’test2’, data () { return { queryInfo: { query: '', pageNum: 1, pageSize: 4, }, queryInfof: { query: '', pageNum: 1, pageSize: 100, }, myChart: ’’, opinionData2: [ //清空前端測試數據 ] } }, mounted: function () { this.drawLine(); }, created() { this.getdateList(); //每次進入頁面刷新數據庫數據實現動態數據綁定 }, methods: { async drawLine () { // 調用post請求,獲得后臺數據庫的數值 const { data: res } = await this.$http.get('alldate', {params: this.queryInfo }); if (res.flag != 'success') {return this.$message.error('該數據獲取失敗!!!'); } console.log(res.flag) this.opinionData2 = res.opinionData2; // 將返回數據賦值 this.myChart = echarts.init(document.getElementById(’myChart’)) this.myChart.setOption({ title: { text: ’網絡日志異常流量分析’, // 主標題 subtext: ’’, // 副標題 x: ’left’ // x軸方向對齊方式 }, grid: { containLabel: true }, tooltip: { trigger: ’item’, formatter: ’{a} <br/>{b} : nppvvxl%’ }, // color: [’#1FC48D’, ’#F5A60A’, ’#6DC8EC’, ’#3F8FFF’], color: [’#1FC48D’, ’red’, ’#6DC8EC’, ’#3F8FFF’], // backgroundColor: ’#ffffff’, legend: { orient: ’vertical’, icon: ’circle’, align: ’left’, x: ’right’, y: ’bottom’, data: [’審計url異常’, ’正常網絡日志’, ’流量日志異常’, ’威脅攻擊日志’] }, series: [ { name: ’網絡日志狀態’, type: ’pie’, radius: [’50%’, ’70%’], avoidLabelOverlap: false, center: [’40%’, ’50%’], itemStyle: { emphasis: { shadowBlur: 10, shadowOffsetX: 0, shadowColor: ’rgba(0, 0, 0, 0.5)’ }, color: function (params) { // 自定義顏色 var colorList = [’#1FC48D’, ’red’, ’#6DC8EC’, ’#3F8FFF’] return colorList[params.dataIndex] } }, data: this.opinionData2 } ] }) }, async getdateList() { // 調用post請求 const { data: res } = await this.$http.get('getupdata', {params: this.queryInfof }); if (res != 'success') {return this.$message.error('該數據獲取失敗!!!'); } console.log(res)}, } } </script>

Springboot運用vue+echarts前后端交互實現動態圓環圖

后臺返回數據:

Springboot運用vue+echarts前后端交互實現動態圓環圖

到此這篇關于Springboot運用vue+echarts前后端交互實現動態圓環圖的文章就介紹到這了,更多相關Springboot vue動態圓環圖 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
日本一区二区免费在线| 亚洲成a人在线观看| 国产精品视频免费| 岛国av在线一区| 欧美午夜影院一区| 午夜精彩视频在线观看不卡| 99免费精品在线| 在线观看91精品国产麻豆| 亚洲gay无套男同| 91久久中文| 欧美国产激情一区二区三区蜜月| 国产成人自拍网| 鲁大师成人一区二区三区| 国产精品久久久久久亚洲毛片| 91在线观看视频| 久久综合九色综合欧美98| 国产在线视频一区二区| 色婷婷久久99综合精品jk白丝| 一区二区三区四区不卡视频 | 国产精品xxx在线观看www| 亚洲精品在线观看网站| 不卡的电影网站| 久久综合九色综合97婷婷女人| 成人免费高清视频| 精品国产91洋老外米糕| jizz一区二区| 337p粉嫩大胆噜噜噜噜噜91av| 国产成人av网站| 日韩视频国产视频| 成人午夜免费av| 精品国产三级a在线观看| 岛国av在线一区| 精品国产一区二区三区久久久蜜月 | 石原莉奈在线亚洲二区| 国产日产精品一区二区三区四区的观看方式 | 亚洲最大成人综合| 中日韩男男gay无套| 亚洲成人精品影院| 91福利视频久久久久| 极品少妇一区二区| 91精品国产综合久久精品app| 国产高清在线精品| 精品国产99国产精品| 91免费在线看| 亚洲欧洲国产专区| 亚洲少妇自拍| 免费看日韩a级影片| 67194成人在线观看| 不卡的av网站| 欧美—级在线免费片| 精品成人一区| 一区二区在线观看视频| 色婷婷综合久久久久中文| 久草在线在线精品观看| 欧美一卡二卡在线| 色综合天天综合网国产成人综合天 | 国产99一区视频免费| 精品少妇一区二区三区免费观看| 91美女片黄在线| 亚洲免费观看在线视频| 亚洲综合三区| 麻豆精品久久久| 精品国产乱码久久久久久免费| 欧美成人一区二免费视频软件| 尤物av一区二区| 欧美性一级生活| 丁香桃色午夜亚洲一区二区三区| 久久精品一区二区三区不卡| 国产精品久久| 亚洲国产欧美日韩另类综合 | 91丨九色丨国产丨porny| 中文字幕视频一区二区三区久| 亚洲专区一区| 国产毛片精品视频| 国产欧美中文在线| 国产亚洲一级| 国产综合色视频| 国产精品欧美极品| 久久国产一区| 懂色av中文一区二区三区| 亚洲国产精品ⅴa在线观看| 亚洲夫妻自拍| 美女视频网站久久| 久久久久久久免费视频了| 国产欧美日韩综合一区在线观看 | 樱花草国产18久久久久| 欧美性色黄大片| 91免费看`日韩一区二区| 一区二区三区日韩在线观看| 欧美日韩精品一二三区| 91浏览器在线视频| 亚洲高清视频中文字幕| 日韩一区二区在线看片| 亚洲一级特黄| 精品一区在线看| 国产日韩欧美一区二区三区乱码| 久久精品人人| 国产精品 日产精品 欧美精品| 亚洲欧美在线视频观看| 欧美亚洲国产一卡| 国产字幕视频一区二区| 麻豆精品蜜桃视频网站| 国产精品久久久久影院老司| 欧美性生交片4| 永久域名在线精品| 国产在线精品一区二区三区不卡| 亚洲图片激情小说| 欧美久久久一区| 亚洲精品美女91| 国产成人高清在线| 亚洲国产精品久久一线不卡| 精品少妇一区二区三区免费观看| 国产婷婷精品| 成人av动漫网站| 日韩高清中文字幕一区| 日本一区二区综合亚洲| 欧美日韩视频在线观看一区二区三区| 国产精品xnxxcom| 国产在线一区观看| 亚洲一级二级在线| 久久久91精品国产一区二区三区| 在线日韩av片| 日韩午夜av在线| fc2成人免费人成在线观看播放| 日韩成人一级片| 国产精品久久午夜夜伦鲁鲁| 777奇米四色成人影色区| 日韩一级网站| 99久久精品免费观看| 免费成人深夜小野草| 亚洲柠檬福利资源导航| 久久亚洲一区二区三区明星换脸| 欧美伊人久久久久久久久影院| 亚洲国产一区二区三区高清| 99久久久无码国产精品| 狠狠久久亚洲欧美| 午夜影视日本亚洲欧洲精品| 日韩理论电影院| 欧美激情在线看| 欧美电视剧免费全集观看| 欧美亚洲另类激情小说| 国产精品乱子乱xxxx| 欧美搞黄网站| 成人黄色小视频在线观看| 久久国产日韩欧美精品| 一区二区三区日韩精品| 欧美—级在线免费片| 欧美大片日本大片免费观看| 欧美在线999| 亚洲欧美日韩精品综合在线观看| 国语自产精品视频在线看8查询8| 成人免费看的视频| 国产麻豆视频精品| 久久成人久久爱| 五月天国产精品| 亚洲一区在线视频| 亚洲视频你懂的| 日本一二三四高清不卡| 欧美成人三级电影在线| 7777精品伊人久久久大香线蕉| 欧美日韩中文另类| 久久综合福利| 久久精品网址| 亚洲欧美日韩精品在线| 国产精品久久波多野结衣| 亚洲精品免费观看| 亚洲精品美女91| 亚洲国产精选| 亚洲第一黄网| 国内精品美女在线观看| 欧美日韩专区| 国产精品国码视频| 午夜久久tv| 国产精品v日韩精品v欧美精品网站| 欧美激情aⅴ一区二区三区| www.在线成人| av不卡在线播放| 91色九色蝌蚪| 欧美色一级片| 国产精品xxx在线观看www| 精品动漫3d一区二区三区免费版 | 国产麻豆成人精品| 国产不卡视频在线观看| 岛国一区二区在线观看| 成人激情综合网站| 成人av综合一区| 欧美激情一区| 亚洲高清精品中出| 国产欧美日韩综合一区在线观看| 免费在线亚洲| 日本韩国欧美国产| 欧美日韩在线综合| 91精品一区二区三区在线观看| 日韩精品一区二区三区蜜臀| 久久久久国产精品麻豆ai换脸 | 亚洲天天做日日做天天谢日日欢 | 成人av动漫网站| 午夜日韩福利| 91久久亚洲| 色就色 综合激情|