日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

SpringBoot+Echarts实现请求后台数据显示饼状图

發布時間:2025/3/19 javascript 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SpringBoot+Echarts实现请求后台数据显示饼状图 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

場景

SpringBoot搭建后臺獲取數據,前端可視化使用echarts的餅狀圖。

Echarts3官網:

https://www.echartsjs.com/index.html

獲取Echarts

從官網下載界面選擇你需要的版本下載,根據開發者功能和體積上的需求,我們提供了不同打包的下載,如果你在體積上沒有要求,可以直接下載完整版本。開發環境建議下載源代碼版本,包含了常見的錯誤提示和警告。

在 ECharts 的 GitHub 上下載最新的 release 版本,解壓出來的文件夾里的 dist 目錄里可以找到最新版本的 echarts 庫。

通過 npm 獲取 echarts,npm install echarts --save,詳見“在 webpack 中使用 echarts”

cdn 引入,你可以在 cdnjs,npmcdn 或者國內的 bootcdn 上找到 ECharts 的最新版本。

引入 ECharts

ECharts 3 開始不再強制使用 AMD 的方式按需引入,代碼里也不再內置 AMD 加載器。因此引入方式簡單了很多,只需要像普通的 JavaScript 庫一樣用 script 標簽引入。

<!DOCTYPE html> <html> <head><meta charset="utf-8"><!-- 引入 ECharts 文件 --><script src="echarts.min.js"></script> </head> </html>

繪制一個簡單的圖表

在繪圖前我們需要為 ECharts 準備一個具備高寬的 DOM 容器。

<body><!-- 為 ECharts 準備一個具備大小(寬高)的 DOM --><div id="main" style="width: 600px;height:400px;"></div> </body>

然后就可以通過 echarts.init 方法初始化一個 echarts 實例并通過 setOption 方法生成一個簡單的柱狀圖,下面是完整代碼。

<!DOCTYPE html> <html> <head><meta charset="utf-8"><title>ECharts</title><!-- 引入 echarts.js --><script src="echarts.min.js"></script> </head> <body><!-- 為ECharts準備一個具備大小(寬高)的Dom --><div id="main" style="width: 600px;height:400px;"></div><script type="text/javascript">// 基于準備好的dom,初始化echarts實例var myChart = echarts.init(document.getElementById('main'));// 指定圖表的配置項和數據var option = {title: {text: 'ECharts 入門示例'},tooltip: {},legend: {data:['銷量']},xAxis: {data: ["襯衫","羊毛衫","雪紡衫","褲子","高跟鞋","襪子"]},yAxis: {},series: [{name: '銷量',type: 'bar',data: [5, 20, 36, 10, 10, 20]}]};// 使用剛指定的配置項和數據顯示圖表。myChart.setOption(option);</script> </body> </html>


這樣你的第一個圖表就誕生了!

以上是官網示例。

實現

html中引入echarts

<script src="https://cdn.bootcss.com/echarts/4.2.1-rc1/echarts-en.common.js"></script> <!-- 為 ECharts 準備一個具備大小(寬高)的 DOM --> <div id="main" style="width: 600px;height:400px;border:1px dashed #000;"></div>

在模板中已經引入jquery,這里不再引入。

編寫js

$(document).ready(function() {// 基于準備好的dom,初始化echarts實例var myChart = echarts.init(document.getElementById('main'));// 指定圖表的配置項和數據var names=[];var values=[];//數據加載完之前先顯示一段簡單的loading動畫myChart.showLoading();$.ajax({type : "post",async : true, //異步請求(同步請求將會鎖住瀏覽器,用戶其他操作必須等待請求完成才可以執行)url : "/wmsLogisticMonitoring/EcharsShow", //請求發送到dataActiont處data : {},dataType : "json", //返回數據形式為jsonsuccess : function(result) {//請求成功時執行該函數內容,result即為服務器返回的json對象if (result) {for(var i=0;i<result.length;i++){names.push(result[i].name);values.push(result[i].num);}myChart.hideLoading(); //隱藏加載動畫myChart.setOption({title: {text: '物料運輸件數',x: 'center'},tooltip: {trigger: 'item',formatter: "{a} <br/>{b} : {c} (ozvdkddzhkzd%)"},legend: {orient: 'vertical',left: 'left',data: names},series: [{name: '物料來源',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) {//請求失敗時執行該函數alert("圖表請求數據失敗!");myChart.hideLoading();}});//end ajax});//刷新方法結束

SpringBoot后臺編寫

編寫實體類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() {} }

編寫后臺Controller

@Description("獲取Echarts數據")@RequestMapping("/EcharsShow")@ResponseBodypublic List<Echarts> echartsShow(Model model) {List<Echarts> list = new ArrayList<Echarts>();list.add(new Echarts("正極車間",100));list.add(new Echarts("負極車間",200));list.add(new Echarts("立體倉庫",300));list.add(new Echarts("清潔車間",400));return list;}

效果

總結

以上是生活随笔為你收集整理的SpringBoot+Echarts实现请求后台数据显示饼状图的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。