Django-Formulare mit CSS gestalten
Bei der Arbeit mit Django-Formularen ist es häufig erforderlich, deren Erscheinungsbild mithilfe von CSS anzupassen. Dies kann erreicht werden, indem Sie bestimmten Formularelementen Klassen oder IDs zuweisen, sodass Sie diese gezielt ansprechen und Stile entsprechend anwenden können.
Betrachten Sie das folgende Django-Formular, das in „forms.py“ definiert ist:
class ContactForm(forms.Form): subject = forms.CharField(max_length=100) email = forms.EmailField(required=False) message = forms.CharField(widget=forms.Textarea)
Und seine HTML-Vorlage in contact_form.html:
<form action="" method="post"> <table> {{ form.as_table }} </table> <input type="submit" value="Submit"> </form>
Um diese Formularelemente zu formatieren, können Sie die Django-Formularklasse so ändern, dass sie benutzerdefinierte Widget-Attribute enthält. Es gibt mehrere Methoden, um dies zu erreichen:
Methode 1:
# forms.py class ContactForm(forms.Form): subject = forms.CharField(widget=forms.TextInput(attrs={'class': 'subject'})) email = forms.EmailField(widget=forms.TextInput(attrs={'class': 'email'})) message = forms.CharField(widget=forms.Textarea(attrs={'class': 'message'}))
Methode 2:
# forms.py class ContactForm(forms.ModelForm): class Meta: model = MyModel def __init__(self, *args, **kwargs): super(ContactForm, self).__init__(*args, **kwargs) self.fields['subject'].widget.attrs.update({'class': 'subject'}) self.fields['email'].widget.attrs.update({'class': 'email'}) self.fields['message'].widget.attrs.update({'class': 'message'})
Methode 3:
# forms.py class ContactForm(forms.ModelForm): class Meta: model = MyModel widgets = { 'subject': forms.TextInput(attrs={'class': 'subject'}), 'email': forms.TextInput(attrs={'class': 'email'}), 'message': forms.Textarea(attrs={'class': 'message'}), }
Durch Hinzufügen Wenn Sie die Klassenattribute mit den Widget-Attributen verbinden, können Sie angeben, welche CSS-Klassen auf die entsprechenden Formularelemente angewendet werden sollen. Anschließend können Sie die erforderlichen CSS-Regeln in Ihrem externen Stylesheet definieren, um deren Erscheinungsbild anzupassen.
Das obige ist der detaillierte Inhalt vonWie kann ich Django-Formulare effektiv mit CSS gestalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!