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和前端进行数据收发

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值