本文实例讲述了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中使用
复制代码 代码如下: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程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。