Flask:如何在基本jinja2模板中放置表单?

时间:2014-06-13 16:49:47

标签: python flask jinja2 flask-wtforms

我是Flask的新手,正在编写一个带搜索工具的简单Flask应用程序。与谷歌搜索类似,我想在搜索结果页面中保留搜索输入框,同时显示结果。因此,我将搜索表单放在基本模板中,并从基本模板中导出搜索结果模板,以显示搜索表单和搜索结果

为此,我做了以下事情: -

带有页面元数据和表单的基本模板(base.html)(即使在结果页面中也应基本存在)。

<html>
  <head>
    {% if title %}
    <title>{{title}}</title>
    {% else %}
    <title>Search</title>
    {% endif %}
  </head>
  <body>
    <h1>Search </h1>
<form action="/series_search" method="post" name="search">
    {{form.hidden_tag()}}
    <p>
        Please enter query: <br>
        {{form.search(size=10)}}
    </p>
    <p><input type="submit" value="Search"></p>
</form>
<br>
{% block content %}{% endblock %}

  </body>
</html>

派生模板(derived.html)具有以下代码,即继承基本模板(具有搜索模板):

{% extends "base.html" %}

{% block content %}
<h1>Search Result</h1>
    {% if result %}
    <p> Title: {{result.title}}</p>
    {% else %}
    <p> search not found!!</p>
    {% endif %}
{% endblock %}

并且,在视图中,以下

@app.route('/search', methods = ['POST', 'GET'])
def search():
    form = SearchForm()
    if form.validate_on_submit():
        print "form validated"
        query = form.search.data
        result = Lib.get_result(query)
        return render_template('derived.html', result = result)
    return render_template('search.html',
    title = 'Search',
    form = form)

如果我输入查询并提交搜索表单,我会收到以下错误,

....
....
File "/Users/webapp/app/templates/derived.html", line 1, in top-level template code
    {% extends "search.html" %}
  File "/Users/webapp/app/templates/search.html", line 12, in top-level template code
    {{form.hidden_tag()}}
  File "/Users/webapp/flask/lib/python2.7/site-packages/jinja2/environment.py", line 397, in getattr
    return getattr(obj, attribute)

因此,基本上按下提交按钮后,视图将呈现派生自base.html的derived.html。 base.html有一个应该设置的表单。

  1. 如何在调用派生模板时传递基本模板的表单对象?
  2. 我的方法是否适合我想达到的目标?如果还有其他,请建议。
  3. 提前感谢你

1 个答案:

答案 0 :(得分:4)

您只需将表单关键字参数传递给其他render_template来电。

return render_template('derived.html', result=result)

应改为:

return render_template('derived.html', result=result, form=form)

需要这样做的原因是因为网络是无状态的 - 渲染的模板不会保存在Flask一侧。就Flask而言,HTML被发送到客户端然后一切都完成了。 POST请求是来自服务器角度的单独请求,唯一被调用的是render_template('derived')调用。创建表单并将其发送到search.html没有“记忆”。