8

有问题的代码:

from flask import Blueprint, render_template, abort
from flask.ext.wtf import Form
import os
from jinja2 import TemplateNotFound
from models import Member
from wtforms.ext.sqlalchemy.orm import model_form
@simple_page.route('/register')
def register():
    form = model_form(Member, Form)
    return render_template('register.html', form=form, name="bad")


class Member(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(50), nullable=False)
    email = db.Column(db.String(50), nullable=False, unique=True)

在我看来:

        <p class="txt11 colorb">
        {{ form.name }}
        </p>

这输出<UnboundField(TextField, (), {u'default': None, u'filters': [], u'validators': [<wtforms.validators.Required object at 0x7f62f59b5590>, <wtforms.validators.Length object at 0x7f62f59b55d0>]})>,而不是实际字段。我如何使用 wtform 获得实际的表单/字段?

4

3 回答 3

12

您将表单而不是表单实例传递给模板。该model_form方法动态生成一个新类,它可以像任何其他表单子类一样被重用、扩展或以其他方式使用。在每次运行视图时生成此表单类也是非常不必要的,因此您可以将此调用移到视图之外。

你传递一个未实例化的类也是你得到与 UnboundField 相关的奇怪行为的原因(这就是 WTForms 处理声明性字段实例化的方式)

修复很简单:

MemberForm = model_form(Member, base_class=Form)

@simple_page.route('/register')
def register():
    form = MemberForm(name=u'bad')
    return render_template('register.html', form=form)
于 2013-05-15T23:30:04.733 回答
3

你需要做更多的工作:

{{ form.name.label }} : {{ form.name()|safe }}

或者,您可以使用这个方便的代码段

{% macro render_field(field) %}
  <dt>{{ field.label }}
  <dd>{{ field(**kwargs)|safe }}
  {% if field.errors %}
    <ul class=errors>
    {% for error in field.errors %}
      <li>{{ error }}</li>
    {% endfor %}
    </ul>
  {% endif %}
  </dd>
{% endmacro %}

当然,调整呈现的 HTML。将该文件保存在templates目录中的某个位置,然后保存在主模板中。这里它formhelpers.html

{% from "formhelpers.html" import render_field %}
<form method=post action="/register">
  <dl>
    {{ render_field(form.name) }}
    {{ render_field(form.email) }}
  </dl>
  <p><input type=submit value=Register>
</form>
于 2013-05-06T20:27:29.937 回答
1

我知道这已经很老了,但我遇到了同样的问题,我想分享我的解决方案以满足未来的需求。

我还得到了“UnboundField”呈现的 html。在与代码斗争后,我发现我正在使用:

from wtforms import Form

它看起来不错,但是在使用 Flask 时我必须这样做:

from flask.ext.wtf import Form

解决了我的问题。希望它有所帮助

于 2014-12-16T08:38:53.007 回答