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

打印 上一主题 下一主题

主题 844|帖子 844|积分 2532

Ajax是异步JavaScript和XML可用于前后端交互,在之前《Flask 框架:运用Ajax实现数据交互》简单实现了前后端交互,本章将通过Ajax轮询获取后端的数据,前台使用echart绘图库进行图形的生成与展示,后台通过render_template方法返回一串JSON数据集,前台收到后将其应用到绘图库上,实现动态监控内存利用率的这个功能。
首先LyShark先来演示一下前端如何运用AJAX实现交互,通过$.ajax定义ajax开始标志,并指定url,type,datetype等信息,通过setInterval设置一个1000毫秒的定时器,每隔一段时间则去后端取数据。
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.    
  6.    
  7. </head>
  8. <body>
  9.    
  10.    
  11. </body>
复制代码
后端只需要根据前端需要的格式返回系统中的CPU利用率(此处模拟),并使用json.dumps({"response":[times,data]})推送到前端即可。
  1. # 署名权
  2. # right to sign one's name on a piece of work
  3. # PowerBy: LyShark
  4. # Email: me@lyshark.com
  5. from flask import Flask,render_template,request
  6. import json,time,random
  7. async_mode = None
  8. app = Flask(import_name=__name__,
  9.             static_url_path='/python',   # 配置静态文件的访问url前缀
  10.             static_folder='static',      # 配置静态文件的文件夹
  11.             template_folder='templates') # 配置模板文件的文件夹
  12. @app.route('/',methods=['POST','GET'])
  13. def index():
  14.     if request.method == "GET":
  15.         return render_template("index.html")
  16.     elif request.method == "POST":
  17.         times = time.strftime("%M:%S", time.localtime())
  18.         data = [random.randint(1,100)]
  19.         return json.dumps({"response":[times,data]})
  20. if __name__ == '__main__':
  21.     app.run()
复制代码
运行这段代码,然后打开控制台,则可以看到如下数据,前台会每隔一秒向后端请求数据;

如果上方绘制可以被正确执行,那么想要实现轮询绘图只需要封装实现一个update()自定义绘图函数,该函数内将得到的数据统一放入到数组内,并调用封装好的display()函数,将数据绘制到前台。
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.    
  6.    
  7. </head>
  8. <body>
  9.    
  10.    
  11. </body><!DOCTYPE html>
  12. <html lang="en">
  13. <head>
  14.     <meta charset="UTF-8">
  15.    
  16.    
  17. </head>
  18. <body>
  19.    
  20.    
  21. </body>               
复制代码
对于后台来说,我们不需要做任何变更,因为只要我们遵循返回JSON的格式即可,运行替换后的程序,我们可以看到控制台会出现以下参数;

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

当然有时候我们需要返回多个图形,而不是一个,运用轮询同样可以实现,如下案例中将两个仪表盘合并在了一起,并通过一个接口实现了数据的轮询,相比上方代码变化并不大。
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.    
  6.    
  7. </head>
  8. <body>
  9.    
  10.    
  11. </body><!DOCTYPE html>
  12. <html lang="en">
  13. <head>
  14.     <meta charset="UTF-8">
  15.    
  16.    
  17. </head>
  18. <body>
  19.    
  20.    
  21. </body>
复制代码
后端部分只需要稍微小改一下,将json.dumps({"response":[cpu,mem]})返回时指定两个参数即可。
  1. # 署名权
  2. # right to sign one's name on a piece of work
  3. # PowerBy: LyShark
  4. # Email: me@lyshark.com
  5. from flask import Flask,render_template,request
  6. import json,time,random
  7. async_mode = None
  8. app = Flask(import_name=__name__,
  9.             static_url_path='/python',   # 配置静态文件的访问url前缀
  10.             static_folder='static',      # 配置静态文件的文件夹
  11.             template_folder='templates') # 配置模板文件的文件夹
  12. @app.route('/',methods=['POST','GET'])
  13. def index():
  14.     if request.method == "GET":
  15.         return render_template("index.html")
  16.     elif request.method == "POST":
  17.         times = time.strftime("%M:%S", time.localtime())
  18.         mem = random.randint(1,100)
  19.         cpu = random.randint(1,100)
  20.         return json.dumps({"response":[cpu,mem]})
  21. if __name__ == '__main__':
  22.     app.run()
复制代码
框架运行后,在前端可以看到两个仪表盘分别显示不同的参数;


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

雁过留声

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表