Flask和WTForms - 如何获取wtforms以刷新选择数据

时间:2012-08-29 04:39:48

标签: python flask wtforms

我正在使用最新版本的flask,wtforms和Flask-WTForms。

我有一个显示表单的页面,一个是带有选项选项“A”的选择框。

当应用程序启动时,一切都很好。在另一种形式中,我添加了一个名为“B”的记录。

现在,我想要的表单应该有选项框和选项A和B bot只有选项A可用。我必须杀死uWSGI并重新启动以获取wtforms来刷新数据。

那么,我错过了什么?如何让wtforms刷新数据?

这是我如何创建表单,其中getAgencyList返回要添加到选择框的选项列表。在另一个对话框中,我添加了代理商,代理商列表应该更新,而无需重新启动应用:

class createUser(Form):
    """
    Users are given a default password
    """
    first_name   = TextField()
    last_name    = TextField()
    email = TextField('Email', [validators.Length(min=6, max=120), validators.Email()])
    user_role = SelectField(u'User Role', choices=[('1', 'User'), ('2', 'Admin')])
    org_role = SelectField(u'User Role', choices=[('1', 'Agency'), ('2', 'Advertiser'),('3', 'Admin')])
    agency = SelectField(u'Agency', choices=getAgencyList())

2 个答案:

答案 0 :(得分:8)

问题是在定义类时会调用getAgencyList()。因此,当时该函数返回的是它的数据。为了更新列表信息,您必须以某种方式在实例化期间运行getAgencyList。为了做到这一点,您可以使用一个非常明显的关于wtforms的事实,它允许您向特定字段添加选项。 documentation is here只查找标题为“选择具有动态选择值的字段”的子部分。这是一个应该有效的代码示例。

class CreateUserForm(Form):
    first_name = TextField()
    last_name = TextField()
    email = TextField('Email', 
            [validators.Length(min=6, max=120), validators.Email()])
    user_role = SelectField(u'User Role', 
            choices=[('1', 'User'), ('2', 'Admin')])
    org_role = SelectField(u'User Role', 
            choices=[('1', 'Agency'), ('2', 'Advertiser'),('3', 'Admin')])
    agency = SelectField(u'Agency')

    @classmethod
    def new(cls):
        # Instantiate the form
        form = cls()

        # Update the choices for the agency field
        form.agency.choices = getAgencyList()
        return form

# So in order to use you do this ...
@app.route('/someendpoint')
def some_flask_endpoint():
    # ... some code ...
    form = CreateUserForm.new()
    # That should give you a working CreateUserForm with updated values.
    # ... some more code to validate form probably...

答案 1 :(得分:1)

一个简单的解决方案是从数据库中获取要显示的选项,然后用以下内容覆盖Form Class:

例如:

def get_agencies():
    agency_list = []
    # get the Agencies from the database - syntax here would be SQLAlchemy
    agencies = Agency.query.all()
    for a in agencies:
        # generate a new list of tuples
        agency_list.append((a.id,a.name))
    return agency_list

@app.route('/somewhere',methods=['POST'])
def somewhere():
    form = createUser()
    # overwrite the choices of the Form Class
    form.agency.choices = get_agencies()
    # here goes the rest of code - like form.validate_on_submit()
    ...
    return render_template('create_user.html', form=form)