和form表单不同的ModelForm,form表单不需要重新规划字段,而是直接从 ORM中取出数据
modelform创建
在models中
class UserType(models.Model):
title = models.CharField(max_length=32)
roles = models.ManyToManyField('Role')
views中
from django.forms import Form,ModelForm
from django.forms import fields
from django.forms import widgets as wd
class UserTypeModeForm(ModelForm):
title = fields.CharField(max_length=6,required=True,widget=wd.Textarea())
class Meta:
model = models.UserType
fields = "__all__"
error_messages = {
'title':{'required':'名称不能为空','invalid':'格式错误'}
}
widgets = {
'title':wd.TextInput(attrs={'class':'c1'})
}
def clean(self):
return self.cleaned_data
class Meta中写入关联的model
新增数据
def user_type_add(request):
if request.method == "GET":
form = UserTypeModeForm()
return render(request,'user_type_add.html',{'form':form})
else:
form = UserTypeModeForm(request.POST)
if form.is_valid():
form.instance.recv_date = ctime
form.save()
return redirect('/usertype/')
else:
return render(request, 'user_type_add.html', {'form': form})
form.save()验证成功之后利用一句话就实现了存储到数据库操作
** form.instance.recv_date = ctime**可以通过form.instance.模型字段添加到clean_data里面
修改数据
def user_type_edit(request,nid):
obj = models.UserType.objects.filter(id=nid).first()
if not obj:
return HttpResponse('...')
if request.method == 'GET':
# 显示默认值
form = UserTypeModeForm(instance=obj)
return render(request,'user_type_edit.html',{'form':form})
else:
print(QueryDict(request.body))
form = UserTypeModeForm(instance=obj,data=request.POST)
if form.is_valid():
form.save()
return redirect('/usertype/')
else:
return render(request, 'user_type_edit.html', {'form': form})
form = UserTypeModeForm(instance=obj,data=request.POST)在修改中需要传入在instance对应的模型对象,再在data传入新数据
ModelForm的相关
ModelForm
a. class Meta:
model, # 对应Model的
fields=None, # 字段
exclude=None, # 排除字段
labels=None, # 提示信息
help_texts=None, # 帮助提示信息
widgets=None, # 自定义插件
error_messages=None, # 自定义错误信息(整体错误信息from django.core.exceptions import NON_FIELD_ERRORS)
field_classes=None # 自定义字段类 (也可以自定义字段)
localized_fields=('birth_date',) # 本地化,如:根据不同时区显示数据
如:
数据库中
2016-12-27 04:10:57
setting中的配置
TIME_ZONE = 'Asia/Shanghai'
USE_TZ = True
则显示:
2016-12-27 12:10:57
b. 验证执行过程
is_valid -> full_clean -> 钩子 -> 整体错误
c. 字典字段验证
def clean_字段名(self):
# 可以抛出异常
# from django.core.exceptions import ValidationError
return "新值"
d. 用于验证
model_form_obj = XXOOModelForm()
model_form_obj.is_valid()
model_form_obj.errors.as_json()
model_form_obj.clean()
model_form_obj.cleaned_data
e. 用于创建
model_form_obj = XXOOModelForm(request.POST)
#### 页面显示,并提交 #####
# 默认保存多对多
obj = form.save(commit=True)
# 不做任何操作,内部定义 save_m2m(用于保存多对多)
obj = form.save(commit=False)
obj.save() # 保存单表信息
obj.save_m2m() # 保存关联多对多信息
f. 用于更新和初始化
obj = model.tb.objects.get(id=1)
model_form_obj = XXOOModelForm(request.POST,instance=obj)
...
PS: 单纯初始化
model_form_obj = XXOOModelForm(initial={...})
ModelForm的ClassMeta
class Meta:
# 这个是input前面的提示
labels = {
'username':'用户名',
'password':'密码',
}
# 这个是input后面的提示
help_texts = {
'username': '* 必须输入用户名',
...
}
# 修改组件的类型和增加类名等
from django.forms import widgets as Fwidgets
widgets = {
'username':Fwidgets.Textarea(attrs={'class':'c1'})
}
# 修改错误信息提示
error_messages = {
# 定义所有的错误信息
'__all__':{
...
}
...
'email':{
'required':'邮箱不能为空',
'invalid':'邮箱格式错误',
}
}
# 自定义匹配格式
field_class:{
...
'email':fields.URLField,
}
# 本地化,时区,
localized_fields = ('ctime',)