gpt4 book ai didi

python - 使用 WTForms 的动态选择字段不更新

转载 作者:行者123 更新时间:2023-11-28 19:32:34 24 4
gpt4 key购买 nike

我正在尝试使用 wtforms 和 sqlalchemy 创建一个动态选择字段,但是当从数据库中插入或删除项目时它不会更新。这是我的代码:

class UserForm(Form):
username = StringField('Username', validators=[DataRequired()])
password = PasswordField('Password', validators=[DataRequired()])
job = SelectField(
'Job',
validators=[DataRequired()],
choices=[(a.id, a.name) for a in Job.query.order_by(Job.name)]
)

和数据库模型:

class Job(db.Model):
id = db.Column(db.Integer, primary_key=True, autoincrement=True)
name = db.Column(db.String)

def __init__(self, name):
self.name = name

def __repr__(self):
return '<Job %s>' % self.name

它成功地在选择字段中显示了作业,但是如果您修改表,它不会更新,除非您完全重新启动应用程序。

最佳答案

您应该在创建表单对象时初始化表单选项:

class UserForm(Form):
username = StringField('Username', validators=[DataRequired()])
password = PasswordField('Password', validators=[DataRequired()])
job = SelectField(
'Job',
validators=[DataRequired()]
)

def __init__(self, *args, **kwargs):
super(UserForm, self).__init__(*args, **kwargs)
self.job.choices = [(a.id, a.name) for a in Job.query.order_by(Job.name)]

或者在 View 中:

form = UserForm()
form.job.choices = [(a.id, a.name) for a in Job.query.order_by(Job.name)]

关于python - 使用 WTForms 的动态选择字段不更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31619747/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com