Flask WTForm作为对AJAX调用的响应

时间:2019-01-27 06:38:49

标签: javascript python ajax flask flask-wtforms

在Flask应用程序中,我试图根据各种按钮选择来“渲染”不同的Flask-WTForms。我还需要更改div的内部HTML,因此尝试按以下方式同时传递innerHTML和表单。我收到表单无法JSON可序列化的错误。

关于如何通过AJAX调用而不是呈现新页面的任何建议?

页面是下面描述的类中的对象。

@app.route('/_select_forms',methods=['GET','POST'])
def _creation_frame():
    content_requested=request.get_json()
    Page=Page_contribute_frame(content_requested)
    return jsonify(html=Page.html_string, form=Page.form)
class Page:
    def __init__(self, **kwargs):
        self.html_string = None
        self.form = None
<div id=contribute-frame></div>
function contribute_frame(e){
  var request_json = frame_identifier();
  $.ajax({
    type:'POST',
    url:'/_contribute_frame',
    contentType: "application/json",
    data:request_json,
    success : function(data){
      $('#contribute-frame').html(data.html);
    },
    error : function (){
      $('#contribute-frame').html('Browser did not get a response. Check connection.');
    }
  });
}````


1 个答案:

答案 0 :(得分:0)

通过渲染字符串在Flask中解决了此问题。

return render_template_string(Page.html_string, form=Page.form)