J'ai une forme assez simple:
from Django import forms
class InitialSignupForm(forms.Form):
email = forms.EmailField()
password = forms.CharField(max_length=255, widget = forms.PasswordInput)
password_repeat = forms.CharField(max_length=255, widget = forms.PasswordInput)
def clean_message(self):
email = self.clean_data.get('email', '')
password = self.clean_data.get('password', '')
password_repeat = self.clean_data.get('password_repeat', '')
try:
User.objects.get(email_address = email)
raise forms.ValidationError("Email taken.")
except User.DoesNotExist:
pass
if password != password_repeat:
raise forms.ValidationError("The passwords don't match.")
Est-ce ainsi que se fait la validation des formulaires personnalisés? J'ai besoin d'évaluer sur email
qu'aucun utilisateur n'existe actuellement avec cette adresse e-mail. Je dois également évaluer que password
et password_repeat
rencontre. Comment puis-je faire cela?
Pour valider un seul champ seul, vous pouvez utiliser une méthode clean_FIELDNAME () dans votre formulaire, donc pour le courrier électronique:
def clean_email(self):
email = self.cleaned_data['email']
if User.objects.filter(email=email).exists():
raise ValidationError("Email already exists")
return email
puis pour les champs co-dépendants qui dépendent les uns des autres, vous pouvez remplacer la méthode forms clean()
qui est exécutée après que tous les champs (comme email
ci-dessus) ont été validés individuellement:
def clean(self):
form_data = self.cleaned_data
if form_data['password'] != form_data['password_repeat']:
self._errors["password"] = ["Password do not match"] # Will raise a error message
del form_data['password']
return form_data
Je ne sais pas d'où vous avez obtenu clean_message()
, mais cela ressemble à une méthode de validation faite pour un champ message
qui ne semble pas exister dans votre formulaire.
Lisez ceci pour plus de détails: