写点什么

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

  • 2022-11-14
    中国香港
  • 本文字数:4545 字

    阅读完需:约 15 分钟

本文分享自华为云社区《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: me@lyshark.com--><!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: me@lyshark.comfrom flask import Flask,render_template,requestimport 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()
复制代码


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



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


<!--	# 署名权	# right to sign one's name on a piece of work	# PowerBy: LyShark	# Email: me@lyshark.com--><!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 的格式即可,运行替换后的程序,我们可以看到控制台会出现以下参数;



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



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


<!--	# 署名权	# right to sign one's name on a piece of work	# PowerBy: LyShark	# Email: me@lyshark.com--><!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: me@lyshark.comfrom flask import Flask,render_template,requestimport 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()
复制代码


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



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

发布于: 刚刚阅读数: 4
用户头像

提供全面深入的云计算技术干货 2020-07-14 加入

华为云开发者社区,提供全面深入的云计算前景分析、丰富的技术干货、程序样例,分享华为云前沿资讯动态,方便开发者快速成长与发展,欢迎提问、互动,多方位了解云计算! 传送门:https://bbs.huaweicloud.com/

评论

发布
暂无评论
Flask框架:如何运用Ajax轮询动态绘图_JavaScript_华为云开发者联盟_InfoQ写作社区