其拉斩灵者,幻浪傲视天地,北京兼职会计
本文实例讲述了python flask框架实现传数据到js的方法。分享给大家供大家参考,具体如下:
首先要清楚后台和前端交互所采用的数据格式。
一般选json,因为和js完美贴合。
后台返回的数据进行序列化
在/homepagerecommend 路由的 view方法中返回序列化数据
dict = {"a":1, "b":2}<br data-filtered="filtered"> 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中使用
js_object = eval('{{result_json|safe }}')
注意 一定要加|safe 过滤否则会对字符串进行转义导致解析错误 使用这种方式传数据,能够在渲染模板的同时传数据,避免定义新的url拿数据
总结: flask 后台给前端js传数据, 需要注意序列化 和反序列化
更多资料参考
希望本文所述对大家基于flask框架的python程序设计有所帮助。
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Python爬虫:Request Payload和Form Data的简单区别说明
浅谈Python中threading join和setDaemon用法及区别说明
Python3-异步进程回调函数(callback())介绍
python继承threading.Thread实现有返回值的子类实例
Python中使用threading.Event协调线程的运行详解
网友评论