本文實例講述了python flask框架實現(xiàn)傳數(shù)據(jù)到j(luò)s的方法。分享給大家供大家參考,具體如下:
首先要清楚后臺和前端交互所采用的數(shù)據(jù)格式。
一般選JSON,因為和js完美貼合。
后臺返回的數(shù)據(jù)進行序列化
在 /homepageRecommend 路由的 view方法中返回序列化數(shù)據(jù)
dict = {"a":1, "b":2}
import json
json.dumps(dict)
2)
from flask import jsonify
jsonify(dict) #在調(diào)用jsonfiy 有時會報錯,原因是jsonify 對象必須是dict
這兩種序列化方式主要的區(qū)別是 jsonify 格式更美觀一些
在前端利用jquary 對json進行反序列化
$.getJSON('/homepageRecommend'
, function(data) { // 從Flask返回的數(shù)據(jù)
alert(data.a) // 瀏覽器彈窗顯示 后端返回的dict["a"]的值,此次是1
}
)
//getJSON 函數(shù)有三個參數(shù)
//第一個是后端返回的數(shù)據(jù)的url
//第二個是要返回給服務(wù)器的data 是可選的
//第三個是對獲取的反序列化數(shù)據(jù) 要繼續(xù)進行的操作的函數(shù)
前端通過
.get()
或者
.get()
或者
.post()
方法發(fā)送請求,后端利用
json.dumps(dict)
返回json數(shù)據(jù),在js中利用
eval()
方法,把json數(shù)據(jù)轉(zhuǎn)換為js對象,后再做其他處理
$.post("{{ url_for('statistics.HomeRecommend') }}",{"id":a},function(reco_list){
var reco_list = eval(reco_list)
//do others
})
最近在使用icharts畫圖的 過程中發(fā)現(xiàn)了另外一種傳數(shù)據(jù)的方式,view中使用
js中直接用
js_object = eval('{{result_json|safe }}')
注意 一定要加|safe 過濾否則會對字符串進行轉(zhuǎn)義導致解析錯誤 使用這種方式傳數(shù)據(jù),能夠在渲染模板的同時傳數(shù)據(jù),避免定義新的url拿數(shù)據(jù)
總結(jié): flask 后臺給前端js傳數(shù)據(jù), 需要注意序列化 和反序列化
更多資料參考 https://www.jb51.net/article/162815.htm
希望本文所述對大家基于Flask框架的Python程序設(shè)計有所幫助。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

