使用 WTForms 的动态 select 字段未更新
Dynamic select field using WTForms not updating
我正在尝试使用 wtforms 和 sqlalchemy 创建一个动态 select 字段,但是当从数据库中插入或删除项目时它不会更新。这是我的代码:
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
它成功地显示了 select 字段中的作业,但是如果您修改 table,它不会更新,除非您完全重新启动应用程序。
您应该在创建表单对象时初始化表单选项:
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)]
或在视图中:
form = UserForm()
form.job.choices = [(a.id, a.name) for a in Job.query.order_by(Job.name)]
值得一提的是@plaes的部分回答是错误的
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)]
在初始化函数中我们应该先调用 super 。然后使用 self.job.choices 否则它不会工作..
在这里查看我的问题
我正在尝试使用 wtforms 和 sqlalchemy 创建一个动态 select 字段,但是当从数据库中插入或删除项目时它不会更新。这是我的代码:
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
它成功地显示了 select 字段中的作业,但是如果您修改 table,它不会更新,除非您完全重新启动应用程序。
您应该在创建表单对象时初始化表单选项:
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)]
或在视图中:
form = UserForm()
form.job.choices = [(a.id, a.name) for a in Job.query.order_by(Job.name)]
值得一提的是@plaes的部分回答是错误的
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)]
在初始化函数中我们应该先调用 super 。然后使用 self.job.choices 否则它不会工作..
在这里查看我的问题