首先,你不应该full_clean像做的那样覆盖。从full_clean的django文档中:
Model.full_clean(exclude=None)
此方法按顺序调用Model.clean_fields()
,Model.clean()
和Model.validate_unique()
,并引发一个ValidationError
,其message_dict
属性包含所有三个阶段的错误。
因此该full_clean
方法已经调用clean
,但是通过覆盖它,可以防止它调用其他两个方法。
其次,调用full_clean
该save方法是一个权衡。请注意,full_clean
当验证模型表单时,例如Django admin中已经调用了它。所以,如果你full_clean
的save方法,那么该方法将运行两次。
通常不期望save方法会引发验证错误,有人可能会调用save
并且无法捕获所产生的错误。但是,我喜欢你调用full_clean
而不是在save方法本身中进行检查-这种方法允许模型表单首先发现问题。
最后,你的clean
方法可以使用,但实际上你可以在model
字段中处理示例案例。定义CharField
为
name = models.CharField(max_length=128)
该blank选项将默认为False
。如果该字段为空白,ValidationError
则在运行时将引发a full_clean。default=None
放入你的容器CharField
并没有任何害处,但是当你实际上不允许将其None
作为值时,这有点令人困惑。