首先,你不应该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作为值时,这有点令人困惑。



