<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
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.com 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()
執行這段程式碼,然後開啟控制檯,則可以看到如下資料,前臺會每隔一秒向後端請求資料;
如果上方繪製可以被正確執行,那麼想要實現輪詢繪圖只需要封裝實現一個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.com 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實現輪詢動態繪圖的文章就介紹到這了,更多相關Flask Ajax輪詢動態繪圖內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45