我有一个包含wtform
的表单,我想使用JobItemForm
向表单JobForm
添加新表单append_entry
。 JobItemForm
已将selectField
命名为company
。我通过这样的模型添加选择字段数据
form.jobs[0].company.choices = company_list
现在我使用append_entry
没有任何选择,我收到错误。那么如何使用一些初始数据调用append_entry
?
class JobItemForm(Form):
company = SelectField(_('company'), description=_('<a href="/education/institute/add/">new company"</a>'))
title = TextField(_('title'), [validators.Length(min=4, max=250)])
date_from = DateField(_("date_from"), format='%Y-%m-%d')
date_to = DateField(_("date_to"), format='%Y-%m-%d')
description = TextAreaField(_('description'))
class JobForm(Form):
jobs = FieldList(FormField(JobItemForm), min_entries=3)
add_job = SubmitField(_('Add job'))
像这样的事情
@mod.route('/edit/', methods=['GET', 'POST'])
@login_required
def edit_job():
"""
edit job
"""
company_list = Company.Company_list()
form_title = "Edit job Form"
if request.method != 'POST':
form = JobForm()
form.jobs[0].company.choices = company_list
return render('form.html', form=form, form_title=form_title)
form = JobForm(request.form)
if form.add_job.data:
new_item_job = form.jobs.append_entry()
new_item_job.company.choices = company_list
return render('form.html', form=form, form_title=form_title)
form.validate
if form.errors != dict():
return render('form.html', form=form, form_title=form_title)
# save data
flash(_("Edit successfully!"))
return render('registration/succesful.html')
答案 0 :(得分:6)
有一种更好的方法:
form.jobs[0].company.choices = company_list
Wtforms有GAE,Django和SQLAlchemy的扩展,它支持orm支持的表单字段。 Documentation of extensions
对于sqlalchemy,它的工作原理如下:
from wtforms.ext.sqlalchemy.fields import QuerySelectField
def fill_field():
return Model.query
myfield = QuerySelectField(query_factory=fill_field)
这段代码会自动从数据库模型中为您填写选项。
(我没有你的实际错误所以我只是在这里猜测)
add_job之后没有选择错误的原因,因为只有当它是GET请求时才填充选项。您需要在Post请求之后添加选项,如下所示:
def your_view():
form = YourForm()
form.fieldname.choices = choice_list
# Here comes your code for GET and POST request both