SpringBoot+Echarts實(shí)現(xiàn)請(qǐng)求后臺(tái)數(shù)據(jù)顯示餅狀圖
場(chǎng)景
SpringBoot搭建后臺(tái)獲取數(shù)據(jù),前端可視化使用echarts的餅狀圖。
Echarts3官網(wǎng)
獲取Echarts
從官網(wǎng)下載界面選擇你需要的版本下載,根據(jù)開(kāi)發(fā)者功能和體積上的需求,我們提供了不同打包的下載,如果你在體積上沒(méi)有要求,可以直接下載完整版本。開(kāi)發(fā)環(huán)境建議下載源代碼版本,包含了常見(jiàn)的錯(cuò)誤提示和警告。
在 ECharts 的 GitHub 上下載最新的 release 版本,解壓出來(lái)的文件夾里的 dist 目錄里可以找到最新版本的 echarts 庫(kù)。
通過(guò) npm 獲取 echarts,npm install echarts --save,詳見(jiàn)“在 webpack 中使用 echarts”
cdn 引入,你可以在 cdnjs,npmcdn 或者國(guó)內(nèi)的 bootcdn 上找到 ECharts 的最新版本。
引入 ECharts
ECharts 3 開(kāi)始不再?gòu)?qiáng)制使用 AMD 的方式按需引入,代碼里也不再內(nèi)置 AMD 加載器。因此引入方式簡(jiǎn)單了很多,只需要像普通的 JavaScript 庫(kù)一樣用 script 標(biāo)簽引入。
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- 引入 ECharts 文件 --> <script src="echarts.min.js"></script> </head> </html>
繪制一個(gè)簡(jiǎn)單的圖表
在繪圖前我們需要為 ECharts 準(zhǔn)備一個(gè)具備高寬的 DOM 容器。
<body> <!-- 為 ECharts 準(zhǔn)備一個(gè)具備大小(寬高)的 DOM --> <div id="main" style="width: 600px;height:400px;"></div> </body>
然后就可以通過(guò) echarts.init 方法初始化一個(gè) echarts 實(shí)例并通過(guò) setOption 方法生成一個(gè)簡(jiǎn)單的柱狀圖,下面是完整代碼。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>ECharts</title>
<!-- 引入 echarts.js -->
<script src="echarts.min.js"></script>
</head>
<body>
<!-- 為ECharts準(zhǔn)備一個(gè)具備大?。▽捀撸┑腄om -->
<div id="main" style="width: 600px;height:400px;"></div>
<script type="text/javascript">
// 基于準(zhǔn)備好的dom,初始化echarts實(shí)例
var myChart = echarts.init(document.getElementById('main'));
// 指定圖表的配置項(xiàng)和數(shù)據(jù)
var option = {
title: {
text: 'ECharts 入門(mén)示例'
},
tooltip: {},
legend: {
data:['銷量']
},
xAxis: {
data: ["襯衫","羊毛衫","雪紡衫","褲子","高跟鞋","襪子"]
},
yAxis: {},
series: [{
name: '銷量',
type: 'bar',
data: [5, 20, 36, 10, 10, 20]
}]
};
// 使用剛指定的配置項(xiàng)和數(shù)據(jù)顯示圖表。
myChart.setOption(option);
</script>
</body>
</html>
這樣你的第一個(gè)圖表就誕生了!
以上是官網(wǎng)示例。
實(shí)現(xiàn)
html中引入echarts
<script src="https://cdn.bootcss.com/echarts/4.2.1-rc1/echarts-en.common.js"></script> <!-- 為 ECharts 準(zhǔn)備一個(gè)具備大小(寬高)的 DOM --> <div id="main" style="width: 600px;height:400px;border:1px dashed #000;"></div>
在模板中已經(jīng)引入jquery,這里不再引入。
編寫(xiě)js
$(document).ready(function() {
// 基于準(zhǔn)備好的dom,初始化echarts實(shí)例
var myChart = echarts.init(document.getElementById('main'));
// 指定圖表的配置項(xiàng)和數(shù)據(jù)
var names=[];
var values=[];
//數(shù)據(jù)加載完之前先顯示一段簡(jiǎn)單的loading動(dòng)畫(huà)
myChart.showLoading();
$.ajax({
type : "post",
async : true, //異步請(qǐng)求(同步請(qǐng)求將會(huì)鎖住瀏覽器,用戶其他操作必須等待請(qǐng)求完成才可以執(zhí)行)
url : "/wmsLogisticMonitoring/EcharsShow", //請(qǐng)求發(fā)送到dataActiont處
data : {},
dataType : "json", //返回?cái)?shù)據(jù)形式為json
success : function(result) {
//請(qǐng)求成功時(shí)執(zhí)行該函數(shù)內(nèi)容,result即為服務(wù)器返回的json對(duì)象
if (result) {
for(var i=0;i<result.length;i++){
names.push(result[i].name);
values.push(result[i].num);
}
myChart.hideLoading(); //隱藏加載動(dòng)畫(huà)
myChart.setOption(
{
title: {
text: '物料運(yùn)輸件數(shù)',
x: 'center'
},
tooltip: {
trigger: 'item',
formatter: "{a} <br/> : {c} (jbfp5pj%)"
},
legend: {
orient: 'vertical',
left: 'left',
data: names
},
series: [
{
name: '物料來(lái)源',
type: 'pie',
radius: '55%',
center: ['50%', '60%'],
data: result,
itemStyle: {
emphasis: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
}
}
]
}
);
}
},
error : function(errorMsg) {
//請(qǐng)求失敗時(shí)執(zhí)行該函數(shù)
alert("圖表請(qǐng)求數(shù)據(jù)失敗!");
myChart.hideLoading();
}
});//end ajax
});//刷新方法結(jié)束
SpringBoot后臺(tái)編寫(xiě)
編寫(xiě)實(shí)體類Echarts
package com.ws.bus.sys.vo.LogisticsMonitoring;
import lombok.Data;
/**
* Created by badao on 2019/5/7.
*/
@Data
public class Echarts {
private String name;
private Integer value;
public Echarts(String name, Integer value) {
this.name = name;
this.value = value;
}
public Echarts() {
}
}
編寫(xiě)后臺(tái)Controller
@Description("獲取Echarts數(shù)據(jù)")
@RequestMapping("/EcharsShow")
@ResponseBody
public List<Echarts> echartsShow(Model model) {
List<Echarts> list = new ArrayList<Echarts>();
list.add(new Echarts("正極車間",100));
list.add(new Echarts("負(fù)極車間",200));
list.add(new Echarts("立體倉(cāng)庫(kù)",300));
list.add(new Echarts("清潔車間",400));
return list;
}
效果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java實(shí)現(xiàn)文件壓縮為zip和解壓zip壓縮包
這篇文章主要為大家介紹了Java如何實(shí)現(xiàn)將文件壓縮為zip以及解壓zip壓縮包,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以動(dòng)手嘗試一下2022-06-06
java 避免出現(xiàn)NullPointerException(空指針)的方法總結(jié)
這篇文章主要介紹了java 避免出現(xiàn)NullPointerException(空指針)的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-09-09
java新增關(guān)聯(lián)的三張表,每張表要求都插入集合,代碼實(shí)現(xiàn)方式
這篇文章主要介紹了java新增關(guān)聯(lián)的三張表,每張表要求都插入集合,代碼實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
IDEA使用SpringAssistant插件創(chuàng)建SpringCloud項(xiàng)目
IDEA 功能強(qiáng)大,可以用來(lái)高效的開(kāi)發(fā)應(yīng)該程序。它還支持第三方插件、用戶可以根據(jù)需要添加自己喜歡的插件。下面介紹如何使用 IDEA 創(chuàng)建 Spring Cloud 項(xiàng)目2021-06-06
詳解springBoot啟動(dòng)時(shí)找不到或無(wú)法加載主類解決辦法
這篇文章主要介紹了詳解springBoot啟動(dòng)時(shí)找不到或無(wú)法加載主類解決辦法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Java使用wait/notify實(shí)現(xiàn)線程間通信下篇
wait()和notify()是直接隸屬于Object類,也就是說(shuō)所有對(duì)象都擁有這一對(duì)方法,下面這篇文章主要給大家介紹了關(guān)于使用wait/notify實(shí)現(xiàn)線程間通信的相關(guān)資料,需要的朋友可以參考下2022-12-12

