我在Django中创建了一个自定义表单对象,它有一个覆盖的__init__方法。覆盖该方法的目的是根据新参数动态生成下拉框。
例如,
class TicketForm(forms.Form):
Type = Type.GetTicketTypeField()
def __init__(self, data=None, files=None, auto_id='id_%s', prefix=None,
initial=None, label_suffix=':', empty_permitted=False,
ticket=None):
if ticket:
self.__class__.State = State.GetTicketStateField(ticket.Type)
super(forms.BaseForm, self ).__init__(data=data, files=files,
auto_id=auto_id, prefix=prefix, initial=initial,
label_suffix=label_suffix, empty_permitted=empty_permitted)
此解决方案无效。看来这些字段是在调用__init__之前创建的。我认为这个问题很常见。 Django处理这些类问题的方法是什么。
答案 0 :(得分:39)
您可以使用self.fields
词典动态修改表单。这样的事可能适合你:
class TicketForm(forms.Form):
Type = Type.GetTicketTypeField()
def __init__(self, ticket, *args, **kwargs):
super(TicketForm, self).__init__(*args, **kwargs)
self.fields['state'] = State.GetTicketStateField(ticket.Type)
答案 1 :(得分:3)
我找到了解决方案here。如果有更好的解决方案,请发回答。
class TicketForm(forms.Form):
Type = Type.GetTicketTypeField()
def __init__(self, ticket=None, *args, **kwargs):
super(TicketForm, self ).__init__(*args, **kwargs)
if ticket:
self.fields['State'] = State.GetTicketStateField(ticket.Type)
答案 2 :(得分:3)
不要修改 var markers = L.markerClusterGroup();
markers.addLayer(L.marker(getRandomLatLng(map)));
// ... Add more layers ...
map.addLayer(markers);
参数。您可能会破坏与 Django 未来版本的兼容性,并使您的代码更难维护。
我建议使用 __init__()
来传递您的变量。
kwargs