Use django-widget-tweaks , é fácil de usar e funciona muito bem.
Caso contrário, isso pode ser feito usando um filtro de modelo personalizado.
Considerando que você processa seu formulário desta maneira:
<form action="/contact/" method="post">
{{ form.non_field_errors }}
<div class="fieldWrapper">
{{ form.subject.errors }}
<label for="id_subject">Email subject:</label>
{{ form.subject }}
</div>
</form>
form.subject é uma instância do BoundField que possui o método as_widget .
você pode criar um filtro personalizado "addcss" em "my_app / templatetags / myfilters.py"
from django import template
register = template.Library()
@register.filter(name='addcss')
def addcss(value, arg):
css_classes = value.field.widget.attrs.get('class', '').split(' ')
if css_classes and arg not in css_classes:
css_classes = '%s %s' % (css_classes, arg)
return value.as_widget(attrs={'class': css_classes})
E depois aplique seu filtro:
{% load myfilters %}
<form action="/contact/" method="post">
{{ form.non_field_errors }}
<div class="fieldWrapper">
{{ form.subject.errors }}
<label for="id_subject">Email subject:</label>
{{ form.subject|addcss:'MyClass' }}
</div>
</form>
O form.subjects será renderizado com a classe css "MyClass".
Espero que esta ajuda.
EDIT 1
EDIT 2
- Atualizar filtro de acordo com o comentário de Bhyd