如果您深入肠中WTForms
,会发现一个名为SelectField
这是称为build html字符串的方法:
@classmethod
def render_option(cls, value, label, selected, **kwargs):
options = dict(kwargs, value=value)
if selected:
options['selected'] = True
return HTMLString('<option %s>%s</option>' % (html_params(**options), escape(text_type(label))))
这是__call__
调用render_options
上面定义的函数的方法。
def __call__(self, field, **kwargs):
kwargs.setdefault('id', field.id)
if self.multiple:
kwargs['multiple'] = True
html = ['<select %s>' % html_params(name=field.name, **kwargs)]
for val, label, selected in field.iter_choices():
html.append(self.render_option(val, label, selected))
html.append('</select>')
return HTMLString(''.join(html))
您将无法class
通过简单地实例化一个属性来添加属性SelectField
。执行此操作时,它将Option
隐式创建实例。在渲染时将render_options
这些隐式实例方法只与调用val
,selected
和label
论据。
您可以Option
在事实之后访问隐式实例。这并非没有问题。如果您查看@Johnston的示例:
>>> i = 44
>>> form = F()
>>> for subchoice in form.a:
... print subchoice(**{'data-id': i})
... i += 1
他正是这样做的。但是您必须在渲染时为类提供属性。该调用subchoice(**{'data-id': i})
实际上吐出了预期的值HTML
。如果要WTForms
与模板引擎集成,则会带来很多问题。因为类似的东西jinja
正在为您调用这些渲染函数。
如果需要这种行为,建议您编写自己的实现SelectField
,使您可以将属性传递给隐式Option
实例。这样,模板引擎就可以处理调用事务,render
并且您可以将表单的定义合并到forms.py
文件中