一 语法
froms.py
class ModelForm(forms.ModelForm):
class Meta:
model=modelsname#指定模型
fields=1 "__all__" 全部 #指定字段值
2 include=[column1,column2] #指定字段
3 exclude=[column1,colum2] # 排查某些字段
labels={'key':'test'} #指定字段说明
err_messages={title:{'required','不能为空'}}
def __init__(self,*args,**kwargs): #批量进行格式化
super().__init__(*args,**kwargs)
for filed in self.fields.values():
filed.error_messages={'required':"该字段不能为空"}
filed.widget.attrs.update({'class':'form-control'})
views.py
form=ModelForm(request.post)
form.save()#数据库保存
二 要点更新
1 ModelForm(instance=object) #object为model查询的可编辑对象,
form =ModelForm(instance=object)
render {form}
三 总结
1 ModelForm会包含Form里的所有东西,而且还扩展了其他一些功能,推荐使用
2 ModelForm同样支持重写clean()函数,自定义验证规则
四 更新功能
一 jinjia2模板
{ % include '*.html' %} 常见于统一的forms表单多处调用,记得加引号
base.html
<form action="" method="POST">
{% csrf_token %}
{% for filed in form %}
<div class="form-row">
<label>{{ filed.label }}</label>
{{ filed}}
<span>{{ filed.errors.0 }}</span>
</div>
{% endfor %}
<input type="submit">
</form>
二 访问构建
1 views函数
def request(request,del_book_id):
2 urls语法
1 re_path('^gengxin/(?P<del_book_id>\d+)/$','views函数)
http://127.0.0.1:8000/del_book_id=1/
正则匹配解析 ?P 分组匹配 del_book_id为字段名 \d+为匹配多个数字
2 path('gengxin/<del_book_id>/','views函数')本文采用
http://127.0.0.1:8000/1/
访问构建
url中的views.method表示不会立刻执行 views.method()会立刻执行
三 更新函数
def gengxin(request,id): #查询更新
object_id=User.objects.get(pk=id)#数据库查询记录
if request.method=='GET': #先进行查询
form=UserForm(instance=object_id)
return render(request,'gengxin.html',locals()) #返回指定记录
elif request.method=='POST': #进行更新表单提交
form=UserForm(request.POST,instance=object_id)
if form.is_valid():
fom.save()此处是更新方法,对应上面的instance
return render(request,'index.html') #进行提交跳转
else:
return render(request, 'gengxin.html',locals())
四 CBV和FBV
FBV----function based view
CBV----class based view 推荐