zoukankan      html  css  js  c++  java
  • python flask下传数据到js

    1. 首先要清楚后台和前端交互所采用的数据格式。
      一般选JSON,因为和js完美贴合。

    2. 后台返回的数据进行序列化
      
      
      在/homepageRecommend 路由的 view方法中返回序列化数据
      1)
      dict = {"a":1, "b":2}
      import json json.dumps(dict) 2) from flask import jsonify jsonify(dict) #在调用jsonfiy 有时会报错,原因是jsonify 对象必须是dict

       这两种序列化方式主要的区别是 jsonify 格式更美观一些

    3. 在前端利用jquary 对json进行反序列化
      $.getJSON('/homepageRecommend'
                      , function(data) {                    // 从Flask返回的数据
                          alert(data.a)                     // 浏览器弹窗显示 后端返回的dict["a"]的值,此次是1
      }
      )
      //getJSON 函数有三个参数 //第一个是后端返回的数据的url //第二个是要返回给服务器的data 是可选的 //第三个是对获取的反序列化数据 要继续进行的操作的函数
    4. 前端通过$.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
      })
    5. 最近在使用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


    
    
     
  • 相关阅读:
    hdu 1116 Play on Words
    hdu 1856 More is better
    跟随鼠标跑
    asp.net实现数据流文件下载
    在ASP.NET程序中集成更好的下载体验
    request.ContentType的可取值
    multipart formdata boundary 说明
    ASP.NET中实现多文件上传(普通)
    读取XML文件中的某个节点的某个属性
    获取请求的Headers部分
  • 原文地址:https://www.cnblogs.com/lazyboy1/p/5015111.html
Copyright © 2011-2022 走看看