Gui*_*ton 3 python django django-models django-forms django-2.0
django 2.0
Run Code Online (Sandbox Code Playgroud)
我有一个django模型,有不同的slug字段:
from django.core.validators import validate_slug
class MyModel(models.Model):
# with slug field
slug_field = models.SlugField(max_length=200)
# or charfield with slug validator (should be exactly the same)
char_field = models.CharField(max_length=200, validators=[validate_slug])
Run Code Online (Sandbox Code Playgroud)
我的第一个问题,在我的形式,我有一个干净的方法,来验证多个字段的值,而不是单独的.理论上应该在clean_fields方法之后调用此方法,但即使clean_fields引发错误也会调用它.
我的forms.py:
class MyForm(forms.ModelForm):
class Meta:
model = MyModel
fields = '__all__'
def clean(self):
cleaned_data = super().clean()
print(cleaned_data.get('slug_field')) # > None
print(cleaned_data.get('char_field')) # > ééé; uncleaned data
print(self.errors) # only from slug_field
return cleaned_data
Run Code Online (Sandbox Code Playgroud)
使用SlugField时,slug_field未设置cleaned_data,当它无效时,以及在引发错误并由表单返回给用户之后.(我不明白为什么clean()甚至达成,因为clean_fields()之前提出过错误)
问题是,使用CharField任何自定义验证器(validate_slug或自制验证器),将返回未清除的值cleaned_data.但是,仍然会提出验证错误,但之后.
这对我来说非常危险,因为我曾经信任cleaned_data,修改未保存在模型中的数据.
该clean()方法是在现场的验证后调用.如果别名无效,那么它将不在cleaned_data.您的clean方法应该处理这种情况,例如:
def clean():
cleaned_data = super().clean()
print(self.errors) # You should see the alias error here
if 'alias' in cleaned_data:
print(cleaned_data['alias'])
# do any code that relies on cleaned_data['alias'] here
return cleaned_data
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
338 次 |
| 最近记录: |