先熟悉该功能源码可以更好的理解
基础判断成功后才进入钩子判断
局部钩子
局部钩子,源码已经定义clean_校验字段(self):
就会自动触发定义判断
'''必须导入该模块才能正常错误提示'''
from django.core.exceptions import NON_FIELD_ERRORS,ValidationError
'''必须有name这个字段才会触发'''
def clean_name(self):
val = self.cleaned_data.get('name') # 获取该字段值
ret = UserInfo.objects.filter(name=val) # 在假定的数据库中判断是否存在用户名
if not ret:
return val # 如果通过校验,那么把值直接原封不动返回即可
else:
raise ValidationError('用户已经注册')
全局钩子
用途:比如密码和确认
密码对比是否相同
模块中
'''必须导入该模块才能正常错误提示'''
from django.core.exceptions import NON_FIELD_ERRORS,ValidationError
def clean(self): # clean=如果通过基础判断
'''在通过基础验证的干净数据中get'''
pwd = self.cleaned_data.get('pwd')
r_pwd = self.cleaned_data.get('r_pwd')
if pwd and r_pwd: # 这里判断一下,如果其中一个连字段校验都没有通过的情况下
if pwd == r_pwd:
'''数据没问题,那么原封不动返回即可'''
return self.cleaned_data
else:
# 错误信息储存到 errors {'__all__':[e,]}
raise ValidationError('两次密码输入不同')
else:
# 没有必要校验全局钩子
return self.cleaned_data
视图中调全局钩子错误信息
if form.is_valid(): # 全部匹配正确
return HttpResponse('OK')
else:
print(form.errors) # 错误的字典可以get错误信息 {字段:错误信息}
# 全局钩子自定义错误提示获取
print(form.errors.get('__all__')[0])
# 错误信息传给模版
error = form.errors.get('__all__')
return render(request, 'reg.html', {'form': form, 'error': error})