python flask下传数据到js
2017-07-09 17:17
274 查看
首先要清楚后台和前端交互所采用的数据格式。
一般选JSON,因为和js完美贴合。
后台返回的数据进行序列化
在/homepageRecommend 路由的 view方法中返回序列化数据
2)
from flask import jsonify
jsonify(dict) #在调用jsonfiy 有时会报错,原因是jsonify 对象必须是dict
这两种序列化方式主要的区别是 jsonify 格式更美观一些
在前端利用jquary 对json进行反序列化
前端通过.get(
4000
)或者.post()方法发送请求,后端利用json.dumps(dict)返回json数据,在js中利用eval()方法,把json数据转换为js对象,后再做其他处理
最近在使用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传数据, 需要注意序列化 和反序列化
更多资料参考 http://docs.jinkan.org/docs/flask/patterns/jquery.html
一般选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(
4000
)或者.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传数据, 需要注意序列化 和反序列化
更多资料参考 http://docs.jinkan.org/docs/flask/patterns/jquery.html
相关文章推荐
- python flask下传数据到js
- Python Web 9 —— flask中在js中如何解析render_template传递给html的数据
- Flask python 传输数据到前台 js 出问题 “&#39; &#34;”
- Python爬虫学习,记一次抓包获取js,从js函数中取数据的过程
- 数据挖掘之----使用 Python & Flask 实现 RESTful Web API
- Python的Flask框架使用Redis做数据缓存的配置方法
- Python 爬虫 PhantomJs 获取JS动态数据
- 用ReactJS和Python的Flask框架编写留言板的代码示例
- python web开发-flask中访问请求数据request
- Python--前端基础之JavaScript(JS的引入方式,JS的变量、常量和标识符,JS的数据类型,运算符,流程控制,JavaScript的对象)
- Python-web: Flask 应用、数据库查询数据、API接口
- Java,php,python,js数据类型
- 如何用python抓取js生成的数据 - SegmentFault
- 前端和后端的数据交互(jquery ajax+python flask+mysql)
- JS Python Flask 处理json 学习笔记
- python网络数据挖掘--JS隐式等待和显式等待
- 用ReactJS和Python的Flask框架编写留言板的代码示例
- toBeContinued h5,bootstrap springboot pythonflask nodejs
- Python的Flask框架应用调用Redis队列数据的方法
- python抓取js加载的数据(phantomjs)