網站首頁 編程語言 正文
在Django開發過程中,遇到了需要圖表進行數據可視化的需要。因此查詢了相關文檔,并記錄下如何實現與圖表的數據交互。 本人是個前端小白,只會改不會寫(套模板)。
僅供參考!!!
環境相關
Django (版本不限,當然不同的版本有不同的后端代碼寫法。本文環境為Django 3.1)
echarts (前端的畫圖框架,導入JS包即可) 點擊網址可以找到模板 網址
JQuery (用于Ajax請求 導入JS包即可 在文中會有JS包地址)
實現思路(需要理解的請結合代碼來看)
- 后端方面主要涉及到了ajax,其實就是前端對后端請求一個特定的地址,后端收到請求后,將數據整理并打包成json格式向前端發送,有點類似于在寫API接口。
- 前端方面。主要有兩個點:echarts 和Ajax 。
- echarts 中可以看到,生成的模板里面有2個data項,用于儲存數據信息制作表格。 (不同的圖表有不同的數據點,本文只有2個data項,生成折線圖)
- Ajax 用于向后端發送請求。
- 在編寫過程中,先將echarts 表的數據項清空(data : [])。 后續通過ajax請求向后端請求數據包,并提取對應的數據加入到echarts 表的數據項中。
代碼:
urls.py
re_path('ajax_line/', views.ajax_line, name='ajax_line'),
ajax請求接口:
from django.db import models
from datetime import datetime
# Create your models here.
class Shop(models.Model):
Name = models.CharField(max_length=50, verbose_name='名稱')
Barcode = models.CharField(max_length=50, verbose_name='條形碼' ,default ='')
Money = models.IntegerField(default=0, verbose_name='單價')
number = models.IntegerField(default=0, verbose_name='庫存')
Other = models.CharField(max_length=100, verbose_name='備注' ,default='無')
objects = models.Manager()
def __str__(self):
return self.Name
class Meta:
verbose_name = '商品'
verbose_name_plural = verbose_name
class ShopOrders(models.Model):
Produce = models.ManyToManyField(Shop, verbose_name='產品清單', blank=True)
Money = models.IntegerField(default=0, verbose_name='合計')
add_time = models.DateTimeField(default=datetime.now, verbose_name='時間')
Other = models.CharField(max_length=100, verbose_name='備注' , default='無')
Owner = models.CharField(max_length=50, verbose_name='銷售人員',default ='')
FRESHMAN = 'FR'
SOPHOMORE = 'SO'
JUNIOR = 'JR'
YEAR_IN_SCHOOL_CHOICES = (
(FRESHMAN, '微信'),
(SOPHOMORE, '現金'),
(JUNIOR, '支付寶'),
)
Type = models.CharField(
max_length=2,
choices=YEAR_IN_SCHOOL_CHOICES,
default=FRESHMAN,
)
objects = models.Manager()
def __str__(self):
return self.Owner
class Meta:
verbose_name = '商品訂單'
verbose_name_plural = verbose_name
models
from django.db import models
from datetime import datetime
# Create your models here.
class Shop(models.Model):
Name = models.CharField(max_length=50, verbose_name='名稱')
Barcode = models.CharField(max_length=50, verbose_name='條形碼' ,default ='')
Money = models.IntegerField(default=0, verbose_name='單價')
number = models.IntegerField(default=0, verbose_name='庫存')
Other = models.CharField(max_length=100, verbose_name='備注' ,default='無')
objects = models.Manager()
def __str__(self):
return self.Name
class Meta:
verbose_name = '商品'
verbose_name_plural = verbose_name
class ShopOrders(models.Model):
Produce = models.ManyToManyField(Shop, verbose_name='產品清單', blank=True)
Money = models.IntegerField(default=0, verbose_name='合計')
add_time = models.DateTimeField(default=datetime.now, verbose_name='時間')
Other = models.CharField(max_length=100, verbose_name='備注' , default='無')
Owner = models.CharField(max_length=50, verbose_name='銷售人員',default ='')
FRESHMAN = 'FR'
SOPHOMORE = 'SO'
JUNIOR = 'JR'
YEAR_IN_SCHOOL_CHOICES = (
(FRESHMAN, '微信'),
(SOPHOMORE, '現金'),
(JUNIOR, '支付寶'),
)
Type = models.CharField(
max_length=2,
choices=YEAR_IN_SCHOOL_CHOICES,
default=FRESHMAN,
)
objects = models.Manager()
def __str__(self):
return self.Owner
class Meta:
verbose_name = '商品訂單'
verbose_name_plural = verbose_name
前端
<!--
THIS EXAMPLE WAS DOWNLOADED FROM https://echarts.apache.org/examples/zh/editor.html?c=line-simple
-->
<!DOCTYPE html>
<html lang="zh-CN" style="height: 100%">
<head>
<meta charset="utf-8">
</head>
<body style="height: 100%; margin: 0">
<h1 style="Text-align:center"> 月度銷售情況</h1>>
<div id="container" style="height: 100%"></div>
<script type="text/javascript" src="https://fastly.jsdelivr.net/npm/echarts@5.3.3/dist/echarts.min.js"></script>
<script type="text/javascript" charset="utf8" src="http://code.jquery.com/jquery-1.10.2.min.js"></script>
<script type="text/javascript">
var dom = document.getElementById('container');
var myChart = echarts.init(dom, null, {
renderer: 'canvas',
useDirtyRect: false
});
var app = {};
var option;
option = {
xAxis: {
type: 'category',
data: []
},
yAxis: {
type: 'value'
},
series: [
{
data: [],
type: 'line'
}
]
};
if (option && typeof option === 'object') {
myChart.setOption(option);
}
window.addEventListener('resize', myChart.resize);
myChart.showLoading();
var names = [];
var brower = [];
$.ajax({ // ajax的方式動態獲取后端代碼
type: 'get',
url: '/index/ajax_line/',
dataType: 'json',
success: function (result) {
$.each(result.data, function (index, item) {
names.push(item.name);
brower.push({
value: item.count,
name: item.name
});
});
myChart.hideLoading();
myChart.setOption({
xAxis: {
data: names
},
series: [{
data: brower
}]
});
},
error: function (errormsg) {
alert('errormsg');
myChart.hideLoading();
}
});
</script>
</body>
</html>
成果展示
參考博客
echarts動態獲取Django數據
原文鏈接:https://blog.csdn.net/qq_42894605/article/details/125890909
相關推薦
- 2022-07-16 gitee設置ssh key
- 2022-11-05 ios開發?try-catch引起的野指針問題排查_IOS
- 2022-06-09 pytorch分類模型繪制混淆矩陣以及可視化詳解_python
- 2022-07-13 SpringBoot中的SmartInitializingSingleton接口的使用
- 2022-12-23 Kubernetes有狀態應用管理StatefulSet使用詳解_云其它
- 2022-04-07 C#實現單例模式的多種方式_C#教程
- 2022-06-28 ES6基礎語法之字符串擴展_基礎知識
- 2023-05-16 iOS開發藍牙技術應用增加無線連接功能_IOS
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支