Django:覆盖自定义表单的__init__

时间:2009-05-15 22:00:05

标签: python django

我在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处理这些类问题的方法是什么。

3 个答案:

答案 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