时间:2021-05-22
modelform是model衍生出来的form .
modelform的用法非常死.
首先在models.py里创建模型表.
所有的form组件单独放在form.py文件,其他地方引入form就可以.
创建modelfrom
只要告诉modelform哪一个模型表,它会自动帮我们比对models模型表字段,并衍生成form组件.它不光给我们提供form组件,还有组件没有的功能.
所有字段都生成form组件.
fields="__all__"
username和password字段生成form组件.
fields=['username','password']
排除gender字段以外都生成form组件.
exclude=['gender']
modelform用在两个地方,一个是添加,一个是编辑.
添加数据
form添加数据先从form取数据,然后在用models插入数据.
modelform直接form.save()就可以插入数据.
编辑数据get请求.
form传值给模板的时候要添加instance数据,否则模板渲染的时候value是空的.
编辑数据post请求.
form.save()的时候要给form添加instance数据,否则会变成create操作,不是update更新操作.
知识点扩展
创建类
from django.forms import ModelFormfrom django.forms import widgets as wdfrom app01 import modelsclass 类名(ModelForm):class Meta:model = models.表名 #models中的表名fields="__all__", # 字段exclude=None, # 排除字段widgets=None, # 自定义插件error_messages=None, # 自定义错误信息(整体错误信息from django.core.exceptions import NON_FIELD_ERRORS)def clean_字段名 #自定义钩子函数实例化对象
form = 类名(instance=obj,data=request.POST)
instance传的是已有的对象(在页面中显示默认值)
data传的是从页面返回过来的值(用户输入的值 ,用来验证)
form.is_valid() #验证
form.save #将数据保存至数据库中(如果有instance参数就修改数据库中的记录,如果没有instance参数就在数据库中添加新的一条记录)
以上这篇基于Django的ModelForm组件(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
上一篇我们写了Django基于类如何增删改数据的方法,方法虽然简单,但新手可能对其原理不是很清楚,那么我们这次就用Django提供的ModelForm方法来实现
本文实例讲述了ReactNative中ScrollView组件轮播图与ListView渲染列表组件用法。分享给大家供大家参考,具体如下:1、ScrollView
Vueprops用法详解组件接受的选项之一props是Vue中非常重要的一个选项。父子组件的关系可以总结为:propsdown,eventsup父组件通过pro
本文实例讲述了yii分页组件用法。分享给大家供大家参考,具体如下:该案例使用时,分页类在yii框架中以组件的形式存在于components中。action代码如
Prop基本用法Prop的基本用法很简单,只需要在子组件的Vue实例中定义该属性并把值设为目标属性的数组即可Vue.component('child',{...