您好,登錄后才能下訂單哦!
本文實(shí)例講述了python flask框架實(shí)現(xiàn)傳數(shù)據(jù)到j(luò)s的方法。分享給大家供大家參考,具體如下:
首先要清楚后臺(tái)和前端交互所采用的數(shù)據(jù)格式。
一般選JSON,因?yàn)楹蚸s完美貼合。
后臺(tái)返回的數(shù)據(jù)進(jìn)行序列化
在/homepageRecommend 路由的 view方法中返回序列化數(shù)據(jù)
dict = {"a":1, "b":2}<br data-filtered="filtered"> import json json.dumps(dict)
2)
from flask import jsonify jsonify(dict) #在調(diào)用jsonfiy 有時(shí)會(huì)報(bào)錯(cuò),原因是jsonify 對象必須是dict
這兩種序列化方式主要的區(qū)別是 jsonify 格式更美觀一些
在前端利用jquary 對json進(jìn)行反序列化
$.getJSON('/homepageRecommend' , function(data) { // 從Flask返回的數(shù)據(jù) alert(data.a) // 瀏覽器彈窗顯示 后端返回的dict["a"]的值,此次是1 } ) //getJSON 函數(shù)有三個(gè)參數(shù) //第一個(gè)是后端返回的數(shù)據(jù)的url //第二個(gè)是要返回給服務(wù)器的data 是可選的 //第三個(gè)是對獲取的反序列化數(shù)據(jù) 要繼續(xù)進(jìn)行的操作的函數(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_object = eval('{{result_json|safe }}')
注意 一定要加|safe 過濾否則會(huì)對字符串進(jìn)行轉(zhuǎn)義導(dǎo)致解析錯(cuò)誤 使用這種方式傳數(shù)據(jù),能夠在渲染模板的同時(shí)傳數(shù)據(jù),避免定義新的url拿數(shù)據(jù)
總結(jié): flask 后臺(tái)給前端js傳數(shù)據(jù), 需要注意序列化 和反序列化
更多資料參考 https://www.jb51.net/article/162815.htm
希望本文所述對大家基于Flask框架的Python程序設(shè)計(jì)有所幫助。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。