欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python flask框架實現(xiàn)傳數(shù)據(jù)到js的方法分析

 更新時間:2019年06月11日 10:00:14   作者:TKtalk  
這篇文章主要介紹了python flask框架實現(xiàn)傳數(shù)據(jù)到js的方法,結(jié)合實例形式分析了前端數(shù)據(jù)序列化及后臺Flask交互數(shù)據(jù)返回相關(guān)操作技巧,需要的朋友可以參考下

本文實例講述了python flask框架實現(xiàn)傳數(shù)據(jù)到js的方法。分享給大家供大家參考,具體如下:

首先要清楚后臺和前端交互所采用的數(shù)據(jù)格式。

一般選JSON,因為和js完美貼合。

后臺返回的數(shù)據(jù)進行序列化

/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 有時會報錯,原因是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
//第二個是要返回給服務器的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中使用

復制代碼 代碼如下:
return render_template('statistics/numberofuserlogin/login_number.html', result_json = json.dumps(result))

js中直接用 js_object = eval('{{result_json|safe }}') 注意 一定要加|safe 過濾否則會對字符串進行轉(zhuǎn)義導致解析錯誤 使用這種方式傳數(shù)據(jù),能夠在渲染模板的同時傳數(shù)據(jù),避免定義新的url拿數(shù)據(jù)

總結(jié): flask 后臺給前端js傳數(shù)據(jù), 需要注意序列化 和反序列化

更多資料參考 http://www.dbjr.com.cn/article/162815.htm

希望本文所述對大家基于Flask框架的Python程序設計有所幫助。

相關(guān)文章

最新評論