python flask框架剖析_python flask框架实现传数据到js的方法分析
本文實例講述了python flask框架實現傳數據到js的方法。分享給大家供大家參考,具體如下:
首先要清楚后臺和前端交互所采用的數據格式。
一般選JSON,因為和js完美貼合。
后臺返回的數據進行序列化
在/homepageRecommend 路由的 view方法中返回序列化數據
dict = {"a":1, "b":2}
import json
json.dumps(dict)
2)
from flask import jsonify
jsonify(dict) #在調用jsonfiy 有時會報錯,原因是jsonify 對象必須是dict
這兩種序列化方式主要的區別是 jsonify 格式更美觀一些
在前端利用jquary 對json進行反序列化
$.getJSON('/homepageRecommend'
, function(data) { // 從Flask返回的數據
alert(data.a) // 瀏覽器彈窗顯示 后端返回的dict["a"]的值,此次是1
}
)
//getJSON 函數有三個參數
//第一個是后端返回的數據的url
//第二個是要返回給服務器的data 是可選的
//第三個是對獲取的反序列化數據 要繼續進行的操作的函數
前端通過.get()或者.get()或者.post()方法發送請求,后端利用json.dumps(dict)返回json數據,在js中利用eval()方法,把json數據轉換為js對象,后再做其他處理
$.post("{{ url_for('statistics.HomeRecommend') }}",{"id":a},function(reco_list){
var reco_list = eval(reco_list)
//do others
})
最近在使用icharts畫圖的 過程中發現了另外一種傳數據的方式,view中使用
復制代碼 代碼如下:return render_template(‘statistics/numberofuserlogin/login_number.html’, result_json = json.dumps(result))
js中直接用js_object = eval('{{result_json|safe }}') 注意 一定要加|safe 過濾否則會對字符串進行轉義導致解析錯誤 使用這種方式傳數據,能夠在渲染模板的同時傳數據,避免定義新的url拿數據
總結: flask 后臺給前端js傳數據, 需要注意序列化 和反序列化
更多資料參考 https://www.jb51.net/article/162815.htm
希望本文所述對大家基于Flask框架的Python程序設計有所幫助。
您可能感興趣的文章:python使用flask與js進行前后臺交互的例子python和flask中返回JSON數據的方法python+flask實現API的方法python實現通過flask和前端進行數據收發
總結
以上是生活随笔為你收集整理的python flask框架剖析_python flask框架实现传数据到js的方法分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 古巴一波音737客机撞鸟 引擎起火客舱浓
- 下一篇: python local_Python3