如果您深入肠中
WTForms,会发现一个名为
SelectField
这是称为build html字符串的方法:
@classmethoddef 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文件中



