Python 如何将初始数据作为默认值附加到新的wtforms FormField?
我有一个带有Python 如何将初始数据作为默认值附加到新的wtforms FormField?,python,flask,wtforms,Python,Flask,Wtforms,我有一个带有wtform的表单,我想使用append\u entry将一个新表单JobItemForm添加到我的表单JobFormJobItemForm具有selectField名称company。我通过这样的模型添加选择字段数据 form.jobs[0].company.choices = company_list @mod.route('/edit/', methods=['GET', 'POST']) @login_required def edit_job(): """
wtform
的表单,我想使用append\u entry
将一个新表单JobItemForm
添加到我的表单JobForm
JobItemForm
具有selectField
名称company
。我通过这样的模型添加选择字段数据
form.jobs[0].company.choices = company_list
@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')
现在我在没有任何选择的情况下使用append\u entry
,收到一个错误。那么我如何用一些初始数据调用append\u 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'))
有一种更好的方法可以做到这一点:
form.jobs[0].company.choices = company_list
Wtforms具有对GAE、Django和SQLAlchemy的扩展,这些扩展支持orm支持的表单字段
对于sqlalchemy,其工作原理如下:
from wtforms.ext.sqlalchemy.fields import QuerySelectField
def fill_field():
return Model.query
myfield = QuerySelectField(query_factory=fill_field)
def your_view():
form = YourForm()
form.fieldname.choices = choice_list
# Here comes your code for GET and POST request both
这段代码自动填充数据库模型中的选项
(我没有你的实际错误,所以我只是在这里猜测)
添加作业后,您没有选择的原因出错,因为您仅在GET请求时填写选择。您也需要在Post请求后添加选项,如下所示:
from wtforms.ext.sqlalchemy.fields import QuerySelectField
def fill_field():
return Model.query
myfield = QuerySelectField(query_factory=fill_field)
def your_view():
form = YourForm()
form.fieldname.choices = choice_list
# Here comes your code for GET and POST request both
试着运行它,看看是否有任何错误,并张贴在这里。我认为它应该运行得很好。@codecool一开始我认为form.jobs[0].company.choices=company\u list是非常难看的代码,它必须在add\u job后的第二秒执行另一种方式,它说其中一项没有选择。如果我在每个请求后添加,但没有删除数据?不,它不会删除数据。当我第一次使用表单的这个choices属性时,我也这么认为,但它需要在每次请求时填写choice。请注意,在使用QuerySelectField时,这不是必需的。