Django пользовательская форма регистрации, которая наследуется от "UserCreationForm"
У меня небольшой вопрос по Django, у меня есть пользовательская форма регистрации, которая наследуется от "UserCreationForm" и поэтому я использую "fields" для определения полей, которые я хочу отобразить. Для этого теста просто ("имя пользователя", "email",). Но когда я перехожу к просмотру моей формы, которая отображается, "Пароль" и "Подтверждение пароля" также присутствуют. Желая понять, я обратился к классу UserCreationForm из django, но у него есть класс Meta, который имеет поля = ("username"), поэтому я не понимаю, почему у меня есть пароли, которые также присутствуют. Извините, что объяснение немного трудоемкое, но я хотел бы понять, так что если у кого-то есть небольшое объяснение, большое спасибо.
Мой пользовательский класс:
class CustomSignupForm(UserCreationForm):
class Meta:
model = CustomUser
fields = ("username", "email",)
Форма UserCreationForm из django:
class UserCreationForm(forms.ModelForm):
"""
A form that creates a user, with no privileges, from the given username and
password.
"""
error_messages = {
"password_mismatch": _("The two password fields didn’t match."),
}
password1 = forms.CharField(
label=_("Password"),
strip=False,
widget=forms.PasswordInput(attrs={"autocomplete": "new-password"}),
help_text=password_validation.password_validators_help_text_html(),
)
password2 = forms.CharField(
label=_("Password confirmation"),
widget=forms.PasswordInput(attrs={"autocomplete": "new-password"}),
strip=False,
help_text=_("Enter the same password as before, for verification."),
)
class Meta:
model = User
fields = ("username",)
field_classes = {"username": UsernameField}
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
if self._meta.model.USERNAME_FIELD in self.fields:
self.fields[self._meta.model.USERNAME_FIELD].widget.attrs[
"autofocus"
] = True
def clean_password2(self):
password1 = self.cleaned_data.get("password1")
password2 = self.cleaned_data.get("password2")
if password1 and password2 and password1 != password2:
raise ValidationError(
self.error_messages["password_mismatch"],
code="password_mismatch",
)
return password2
def _post_clean(self):
super()._post_clean()
# Validate the password after self.instance is updated with form data
# by super().
password = self.cleaned_data.get("password2")
if password:
try:
password_validation.validate_password(password, self.instance)
except ValidationError as error:
self.add_error("password2", error)
def save(self, commit=True):
user = super().save(commit=False)
user.set_password(self.cleaned_data["password1"])
if commit:
user.save()
return user
Вот что это дает:
Причина, по которой это происходит, заключается в том, что поле password1 и поле password2 определены в классе UserCreationForm. Поля формы не нужно перечислять в атрибуте fields: все объекты поля в классе являются полями формы.
А ModelForm по сути добавит объекты поля формы в класс, и таким образом автоматизирует этот процесс, но любой объект поля, определенный в классе, является полем формы, именно так ведет себя простой Form [Django-doc], а ModelForm - это просто подкласс Form.
Based on your comment you want to reorder the fields. You can do so with the .field_order attribute [Django-doc]:
class CustomSignupForm(UserCreationForm):
field_order = ('username', 'email', 'password1', 'password2', 'newsletter')
class Meta:
model = CustomUser
fields = ('username', 'email', 'newsletter')