首页 > 其他分享 >Flask框架:如何运用Ajax轮询动态绘图

Flask框架:如何运用Ajax轮询动态绘图

时间:2022-11-14 11:03:44浏览次数:70  
标签:__ function name Flask 轮询 Ajax time recv response

本文分享自华为云社区《​​Flask框架:运用Ajax轮询动态绘图​​》,作者:LyShark。

Ajax是异步JavaScript和XML可用于前后端交互,在之前​​《Flask 框架:运用Ajax实现数据交互》​​简单实现了前后端交互,本章将通过​​Ajax​​轮询获取后端的数据,前台使用​​echart​​绘图库进行图形的生成与展示,后台通过​​render_template​​方法返回一串JSON数据集,前台收到后将其应用到绘图库上,实现动态监控内存利用率的这个功能。

首先​​LyShark​​先来演示一下前端如何运用AJAX实现交互,通过​​$.ajax​​定义ajax开始标志,并指定​​url,type,datetype​​等信息,通过​​setInterval​​设置一个1000毫秒的定时器,每隔一段时间则去后端取数据。

<!--
# 署名权
# right to sign one's name on a piece of work
# PowerBy: LyShark
# Email: [email protected]
-->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.lyshark.com/javascript/echarts/5.3.0/echarts.min.js"></script>
</head>
<body>
<!--设定一个定时器,每隔1000毫秒向后端发送请求-->
<script type="text/javascript">
$(
function () {
fetchData();
setInterval(fetchData, 1000);
}
);
function fetchData(){
$.ajax({
url:"/",
type:"POST",
dataType: 'json',
success:function (recv) {
console.log("[lyshark.com] 获取到时间:" + recv.response[0]);
console.log("[lyshark.com] 获取到数据:" + recv.response[1]);
}
})
}
</script>
</body>

后端只需要根据前端需要的格式返回系统中的CPU利用率(此处模拟),并使用​​json.dumps({"response":[times,data]})​​推送到前端即可。

# 署名权
# right to sign one's name on a piece of work
# PowerBy: LyShark
# Email: [email protected]
from flask import Flask,render_template,request
import json,time,random

async_mode = None

app = Flask(import_name=__name__,
static_url_path='/python', # 配置静态文件的访问url前缀
static_folder='static', # 配置静态文件的文件夹
template_folder='templates') # 配置模板文件的文件夹

@app.route('/',methods=['POST','GET'])
def index():
if request.method == "GET":
return render_template("index.html")

elif request.method == "POST":
times = time.strftime("%M:%S", time.localtime())
data = [random.randint(1,100)]
return json.dumps({"response":[times,data]})

if __name__ == '__main__':
app.run()

运行这段代码,然后打开控制台,则可以看到如下数据,前台会每隔一秒向后端请求数据;

Flask框架:如何运用Ajax轮询动态绘图_json

如果上方绘制可以被正确执行,那么想要实现轮询绘图只需要封装实现一个​​update()​​自定义绘图函数,该函数内将得到的数据统一放入到数组内,并调用封装好的​​display()​​函数,将数据绘制到前台。

<!--
# 署名权
# right to sign one's name on a piece of work
# PowerBy: LyShark
# Email: [email protected]
-->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.lyshark.com/javascript/echarts/5.3.0/echarts.min.js"></script>
</head>
<body>
<!--定义绘图区域-->
<div id="main" style="height:300px;width:80%;border:1px solid #eecc11;padding:10px;"></div>

<!--调用百度的绘图库,进行图片的绘制工作.-->
<script type="text/javascript" charset="UTF-8">
var display = function(time,cpu) {
var main = echarts.init(document.getElementById(("main")));
var option = {
xAxis: {
boundaryGap:false,
boundaryGap:false,
type: 'category',
data: time
},
yAxis: {
type: 'value'
},
series: [{
type: 'line',
areaStyle:{},
data: cpu
}]
};
main.setOption(option,true);
};
</script>

<!--update()函数具体执行的任务,其主要只保留前十条数据.-->
<script type="text/javascript" charset="UTF-8">
// 负责对参数的解析
var time =["","","","","","","","","",""];
var cpu = [0,0,0,0,0,0,0,0,0,0];
var update = function(recv){
time.push(recv.response[0]);
cpu.push(parseFloat(recv.response[1]));
if(time.length >=10){
time.shift();
cpu.shift();
console.log("处理后的时间数据:" + time);
console.log("处理后的CPU数据:" + cpu);
display(time,cpu) // 调用绘图函数
}
};
</script>

<!--设定一个定时器,每隔1000毫秒向后端发送请求-->
<script type="text/javascript">
$(
function () {
fetchData();
setInterval(fetchData, 1000);
}
);
function fetchData(){
$.ajax({
url:"/",
type:"POST",
dataType: 'json',
success:function (recv) {
console.log("获取到时间:" + recv.response[0]);
console.log("获取到数据:" + recv.response[1]);

// 传递给处理函数
update(recv)
}
})
}
</script>
</body>

对于后台来说,我们不需要做任何变更,因为只要我们遵循返回JSON的格式即可,运行替换后的程序,我们可以看到控制台会出现以下参数;

Flask框架:如何运用Ajax轮询动态绘图_javascript_02

这就标志着接收的数据是正确的,我们来看下最终绘制效果;

Flask框架:如何运用Ajax轮询动态绘图_json_03

当然有时候我们需要返回多个图形,而不是一个,运用轮询同样可以实现,如下案例中将两个仪表盘合并在了一起,并通过一个接口实现了数据的轮询,相比上方代码变化并不大。

<!--
# 署名权
# right to sign one's name on a piece of work
# PowerBy: LyShark
# Email: [email protected]
-->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="https://cdn.lyshark.com/javascript/jquery/3.5.1/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.lyshark.com/javascript/echarts/5.3.0/echarts.min.js"></script>
</head>
<body>
<!--定义绘图区域-->
<div id="cpuChart" style="width: 20%; height: 300px; border: 1px solid #dddddd; float:left; margin-right: 8px;"></div>
<div id="memChart" style="width: 20%; height: 300px; border: 1px solid #dddddd; float:left; margin-right: 8px;"></div>

<!--封装方法,一次性绘制两个图形-->
<script type="text/javascript" charset="UTF-8">
var display = function(cpu,mem)
{
var cpuChart = echarts.init(document.getElementById("cpuChart"));
var option = {
series: [
{
name: 'Pressure',
type: 'gauge',
progress: {
show: true
},
detail: {formatter: '{value} %',fontSize: 12},
data: [{value: cpu, name: 'CPU负载'}]
}
]
};cpuChart.setOption(option, true);

var memChart = echarts.init(document.getElementById("memChart"));
var option = {
series: [
{
name: 'Pressure',
type: 'gauge',
progress: {
show: true
},
detail: {formatter: '{value} %',fontSize: 12},
data: [{value: mem, name: '内存利用率'}]
}
]
};memChart.setOption(option, true);
};
</script>

<!--定义轮巡-->
<script type="text/javascript">
$(
function () {
fetchData();
setInterval(fetchData, 100);
}
);
function fetchData(){
$.ajax({
url:"/",
type:"POST",
dataType: 'json',
success:function (recv) {
display(recv.response[0],recv.response[1]);
}
})
}
</script>
</body>

后端部分只需要稍微小改一下,将​​json.dumps({"response":[cpu,mem]})​​返回时指定两个参数即可。

# 署名权
# right to sign one's name on a piece of work
# PowerBy: LyShark
# Email: [email protected]
from flask import Flask,render_template,request
import json,time,random

async_mode = None

app = Flask(import_name=__name__,
static_url_path='/python', # 配置静态文件的访问url前缀
static_folder='static', # 配置静态文件的文件夹
template_folder='templates') # 配置模板文件的文件夹

@app.route('/',methods=['POST','GET'])
def index():
if request.method == "GET":
return render_template("index.html")

elif request.method == "POST":
times = time.strftime("%M:%S", time.localtime())
mem = random.randint(1,100)
cpu = random.randint(1,100)
return json.dumps({"response":[cpu,mem]})

if __name__ == '__main__':
app.run()

框架运行后,在前端可以看到两个仪表盘分别显示不同的参数;

Flask框架:如何运用Ajax轮询动态绘图_数据_04

点击关注,第一时间了解华为云新鲜技术~


标签:__,function,name,Flask,轮询,Ajax,time,recv,response
From: https://blog.51cto.com/u_15214399/5848515

相关文章

  • 8.Ajax研究(2)
    6.SpringMVC实现Ajax。1.实体类User@Data@AllArgsConstructor@NoArgsConstructorpublicclassUser{privateintage;privateStringname;privateS......
  • 2211-13 flask模板
    第3章:模板在一般的Web程序里,访问一个地址通常会返回一个包含各类信息的HTML页面。因为我们的程序是动态的,页面中的某些信息需要根据不同的情况来进行调整,比如对登录......
  • 2211-12 Hello Flask!
    本篇记录来自Flask入门教程第2章:Hello,Flask!第2章:Hello,Flask!追溯到最初,Flask诞生于ArminRonacher在2010年愚人节开的一个玩笑。后来,它逐渐发展成为一个......
  • (作者推荐)【RocketMQ入门到精通】— RocketMQ中级特性能力 | ​长轮询Pull和Push模式
    名言警句任何先进的技术均与魔法无异追本溯源【​​经历了6个月的失踪,我将带着干货终究归来!【RocketMQ入门到精通】​​】RocketMQ消费机制回顾   在众多MQ的体系中,一......
  • Ajax从入门到精通
    #三句话让AJAX为我欲罢不能大家好,我是精通AJAX的猿类高质量雄性码农,三句话让AJAX为我欲罢不能什么是AJAX?为什么要AJAX?怎么AJAX?下面就带着这三句话,来一起......
  • JS 封装ajax
    functionAjax(url,params){returnnewPromise((resolve,reject)=>{$.ajax({url:url,......
  • 2211-11Flask入门教程
    本篇记录来自Flask入门教程准备工作在通过这本书学习Flask开发前,我假设你已经了解了Python和HTML的基础知识。如果还没有,那么可以先从下面这些在线资源入手:《使用......
  • ajax获取数据,数据库查询
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><title>Document</......
  • JS的原生的Ajax(一)
    古语有云:万恶淫为首,百善孝为先。我们后辈当自勉。这是最下面的一章,没有了,​​跳转到主页​​一.AjaxAjax,全称是AsynchronousJavaScriptAndXML,异步JavaScript......
  • 什么情况下发送ajax会触发页面跳转
    button标签没有加type属性,因为浏览器会认为button按钮默认类型是submit 会提交数据 请始终为按钮规定type属性。InternetExplorer的默认类型是"button",而其他浏......