django form 和modelform
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了django form 和modelform,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含30713字,纯文字阅读大概需要44分钟。
内容图文
本节目录
我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来。
与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户是否输入,输入的长度和格式等正不正确。如果用户输入的内容有错误就需要在页面上相应的位置显示对应的错误信息.。
Django form组件就实现了上面所述的功能。
总结一下,其实form组件的主要功能如下:
生成页面可用的HTML标签
对用户提交的数据进行校验
保留上次输入内容
普通方式手写注册功能
views.py
# 注册 def register(request): error_msg = ""if request.method == "POST": username = request.POST.get("name") pwd = request.POST.get("pwd") # 对注册信息做校验if len(username) < 6: # 用户长度小于6位 error_msg = "用户名长度不能小于6位"else: # 将用户名和密码存到数据库return HttpResponse("注册成功") return render(request, "register.html", {"error_msg": error_msg})
login.html
<! DOCTYPE html > < html lang ="en" > < head > < meta charset ="UTF-8" > < title >注册页面</title></head><body><form action="/reg/" method="post"> {% csrf_token %} <p> 用户名: <input type="text" name="name"></p><p> 密码: <input type="password" name="pwd"></p><p><input type="submit" value="注册"><p style="color: red">{{ error_msg }}</p></p></form></body></html>
使用form组件实现注册功能
views.py
先定义好一个RegForm类:
from django import forms # 按照Django form组件的要求自己写一个类
class RegForm(forms.Form):
name = forms.CharField(label="用户名") #form字段的名称写的是什么,那么前端生成input标签的时候,input标签的name属性的值就是什么
pwd = forms.CharField(label="密码")
再写一个视图函数:
# 使用form组件实现注册方式 def register2(request): form_obj = RegForm() if request.method == "POST": # 实例化form对象的时候,把post提交过来的数据直接传进去 form_obj = RegForm(data=request.POST) #既然传过来的input标签的name属性值和form类对应的字段名是一样的,所以接过来后,form就取出对应的form字段名相同的数据进行form校验 # 调用form_obj校验数据的方法if form_obj.is_valid(): return HttpResponse("注册成功") return render(request, "register2.html", {"form_obj": form_obj})
login2.html
<! DOCTYPE html > < html lang ="en" > < head > < meta charset ="UTF-8" > < title >注册2</title></head><body><form action="/reg2/" method="post" novalidate autocomplete="off"> #novalidate 告诉前端form表单,不要对输入的内容做校验 {% csrf_token %}
#{{ form_obj.as_p }} 直接写个这个,下面的用户名和密码的标签不自己写,你看看效果 <div><label for="{{ form_obj.name.id_for_label }}">{{ form_obj.name.label }}</label> {{ form_obj.name }} {{ form_obj.name.errors.0 }} #errors是这个字段所有的错误,我就用其中一个错误提示就可以了,再错了再提示,并且不是给你生成ul标签了,单纯的是错误文本
{{ form_obj.errors }} #这是全局的所有错误,找对应字段的错误,就要form_obj.字段名 </div><div><label for="{{ form_obj.pwd.id_for_label }}">{{ form_obj.pwd.label }}</label> {{ form_obj.pwd }} {{ form_obj.pwd.errors.0 }} </div><div><input type="submit" class="btn btn-success" value="注册"></div></form></body></html>
看网页效果发现 也验证了form的功能:
前端页面是form类的对象生成的 -->生成HTML标签功能
当用户名和密码输入为空或输错之后 页面都会提示 -->用户提交校验功能
当用户输错之后 再次输入 上次的内容还保留在input框 -->保留上次输入内容
创建Form类时,主要涉及到 【字段】 和 【插件】,字段用于对用户请求数据的验证,插件用于自动生成HTML;
initial
初始值,input框里面的初始值。
class LoginForm(forms.Form): username = forms.CharField( min_length=8, label="用户名", initial="张三"# 设置默认值 ) pwd = forms.CharField(min_length=6, label="密码")
error_messages
重写错误信息。
class LoginForm(forms.Form): username = forms.CharField( min_length=8, label="用户名", initial="张三", error_messages={ "required": "不能为空", "invalid": "格式错误", "min_length": "用户名最短8位" } ) pwd = forms.CharField(min_length=6, label="密码")
password
class LoginForm(forms.Form): ... pwd = forms.CharField( min_length=6, label="密码", widget=forms.widgets.PasswordInput(attrs={‘class‘: ‘c1‘}, render_value=True) #这个密码字段和其他字段不一样,默认在前端输入数据错误的时候,点击提交之后,默认是不保存的原来数据的,但是可以通过这个render_value=True让这个字段在前端保留用户输入的数据 )
radioSelect
单radio值为字符串
class LoginForm(forms.Form): username = forms.CharField( #其他选择框或者输入框,基本都是在这个CharField的基础上通过插件来搞的 min_length=8, label="用户名", initial="张三", error_messages={ "required": "不能为空", "invalid": "格式错误", "min_length": "用户名最短8位" } ) pwd = forms.CharField(min_length=6, label="密码") gender = forms.fields.ChoiceField( choices=((1, "男"), (2, "女"), (3, "保密")), label="性别", initial=3, widget=forms.widgets.RadioSelect() )
单选Select
class LoginForm(forms.Form): ... hobby = forms.fields.ChoiceField( #注意,单选框用的是ChoiceField,并且里面的插件是Select,不然验证的时候会报错, Select a valid choice的错误。 choices=((1, "篮球"), (2, "足球"), (3, "双色球"), ), label="爱好", initial=3, widget=forms.widgets.Select() )
多选Select
class LoginForm(forms.Form): ... hobby = forms.fields.MultipleChoiceField( #多选框的时候用MultipleChoiceField,并且里面的插件用的是SelectMultiple,不然验证的时候会报错。 choices=((1, "篮球"), (2, "足球"), (3, "双色球"), ), label="爱好", initial=[1, 3], widget=forms.widgets.SelectMultiple() )
单选checkbox
class LoginForm(forms.Form): ... keep = forms.fields.ChoiceField( label="是否记住密码", initial="checked", widget=forms.widgets.CheckboxInput() )
单选checkbox示例:
# 单选的checkbox class TestForm2(forms.Form): keep = forms.ChoiceField( choices=( (‘True‘,1), (‘False‘,0), ),label</span>=<span style="color: #800000;">"</span><span style="color: #800000;">是否7天内自动登录</span><span style="color: #800000;">"</span><span style="color: #000000;">, initial</span>=<span style="color: #800000;">"</span><span style="color: #800000;">1</span><span style="color: #800000;">"</span><span style="color: #000000;">, widget</span>=<span style="color: #000000;">forms.widgets.CheckboxInput(), ) 选中:</span><span style="color: #800000;">‘</span><span style="color: #800000;">True</span><span style="color: #800000;">‘</span> <span style="color: #008000;">#</span><span style="color: #008000;">form只是帮我们做校验,校验选择内容的时候,就是看在没在我们的choices里面,里面有这个值,表示合法,没有就不合法</span> 没选中:<span style="color: #800000;">‘</span><span style="color: #800000;">False</span><span style="color: #800000;">‘</span> ---保存到数据库里面 keep:<span style="color: #800000;">‘</span><span style="color: #800000;">True</span><span style="color: #800000;">‘</span> <span style="color: #0000ff;">if</span> keep == <span style="color: #800000;">‘</span><span style="color: #800000;">True</span><span style="color: #800000;">‘</span><span style="color: #000000;">: session 设置有效期7天 </span><span style="color: #0000ff;">else</span><span style="color: #000000;">: </span><span style="color: #0000ff;">pass</span></pre>
多选checkbox
class LoginForm(forms.Form): ... hobby = forms.fields.MultipleChoiceField( choices=((1, "篮球"), (2, "足球"), (3, "双色球"),), label="爱好", initial=[1, 3], widget=forms.widgets.CheckboxSelectMultiple() )
date类型
from django import forms from django.forms import widgets class BookForm(forms.Form): date = forms.DateField(widget=widgets.TextInput(attrs={‘type‘:‘date‘})) #必须指定type,不然不能渲染成选择时间的input框
choice字段注意事项
在使用选择标签时,需要注意choices的选项可以配置从数据库中获取,但是由于是静态字段 获取的值无法实时更新,需要重写构造方法从而实现choice实时更新。
方式一:
from django.forms import Form from django.forms import widgets from django.forms import fields class MyForm(Form):user </span>=<span style="color: #000000;"> fields.ChoiceField( </span><span style="color: #008000;">#</span><span style="color: #008000;"> choices=((1, ‘上海‘), (2, ‘北京‘),),</span> initial=2<span style="color: #000000;">, widget</span>=<span style="color: #000000;">widgets.Select ) </span><span style="color: #0000ff;">def</span> <span style="color: #800080;">__init__</span>(self, *args, **<span style="color: #000000;">kwargs): super(MyForm,self).</span><span style="color: #800080;">__init__</span>(*args, **<span style="color: #000000;">kwargs) #注意重写init方法的时候,*args和**kwargs一定要给人家写上,不然会出问题,并且验证总是不能通过,还不显示报错信息 </span><span style="color: #008000;">#</span><span style="color: #008000;"> self.fields[‘user‘].choices = ((1, ‘上海‘), (2, ‘北京‘),)</span> <span style="color: #008000;">#</span><span style="color: #008000;"> 或</span> self.fields[<span style="color: #800000;">‘</span><span style="color: #800000;">user</span><span style="color: #800000;">‘</span>].choices = models.Classes.objects.all().values_list(<span style="color: #800000;">‘</span><span style="color: #800000;">id</span><span style="color: #800000;">‘</span>,<span style="color: #800000;">‘</span><span style="color: #800000;">caption</span><span style="color: #800000;">‘</span>)</pre>
方式二:
from django import forms from django.forms import fields from django.forms import models as form_model class FInfo(forms.Form):
authors = forms.ModelMultipleChoiceField(queryset=models.NNewType.objects.all()) # 多选
#或者下面这种方式,通过forms里面的models中提供的方法也是一样的。
authors = form_model.ModelMultipleChoiceField(queryset=models.NNewType.objects.all()) # 多选#authors = form_model.ModelChoiceField(queryset=models.NNewType.objects.all()) # 单选
#或者,forms.ModelChoiceField(queryset=models.Publisth.objects.all(),widget=forms.widgets.Select()) 单选
#
authors = forms.ModelMultipleChoiceField(
queryset=models.Author.objects.all(),
widget = forms.widgets.Select(attrs={‘class‘: ‘form-control‘}
))
#如果用这种方式,别忘了model表中,NNEWType的__str__方法要写上,不然选择框里面是一个个的object对象
内置字段:
Field required=True, 是否允许为空 widget=None, HTML插件 label=None, 用于生成Label标签或显示内容 initial=None, 初始值 help_text=‘‘, 帮助信息(在标签旁边显示) error_messages=None, 错误信息 {‘required‘: ‘不能为空‘, ‘invalid‘: ‘格式错误‘} validators=[], 自定义验证规则 localize=False, 是否支持本地化 disabled=False, 是否可以编辑 label_suffix=None Label内容后缀CharField(Field)
=None, 最大长度
max_length
min_length=None, 最小长度
strip=True 是否移除用户输入空白IntegerField(Field)
=None, 最大值
max_value
min_value=None, 最小值FloatField(IntegerField)
...DecimalField(IntegerField)
=None, 最大值
max_value
min_value=None, 最小值
max_digits=None, 总长度
decimal_places=None, 小数位长度BaseTemporalField(Field)
=None 时间格式化
input_formatsDateField(BaseTemporalField) 格式:
2015-09-01
TimeField(BaseTemporalField) 格式:11:12
DateTimeField(BaseTemporalField)格式:2015-09-01 11:12DurationField(Field) 时间间隔:
%d %H:%M:%S.%f
...RegexField(CharField)
=None, 最大长度
regex, 自定制正则表达式
max_length
min_length=None, 最小长度
error_message=None, 忽略,错误信息使用 error_messages={‘invalid‘: ‘...‘}EmailField(CharField)
...FileField(Field)
=False 是否允许空文件
allow_empty_fileImageField(FileField)
- form表单中 enctype="multipart/form-data"
...
注:需要PIL模块,pip3 install Pillow
以上两个字典使用时,需要注意两点:
- view函数中 obj = MyForm(request.POST, request.FILES)URLField(Field)
...BooleanField(Field)
...NullBooleanField(BooleanField)
...ChoiceField(Field)
=(), 选项,如:choices = ((0,‘上海‘),(1,‘北京‘),)
...
choices
required=True, 是否必填
widget=None, 插件,默认select插件
label=None, Label内容
initial=None, 初始值
help_text=‘‘, 帮助提示ModelChoiceField(ChoiceField)
# 查询数据库中的数据
... django.forms.models.ModelChoiceField
queryset,
empty_label="---------", # 默认空显示内容
to_field_name=None, # HTML中value的值对应的字段
limit_choices_to=None # ModelForm中对queryset二次筛选
ModelMultipleChoiceField(ModelChoiceField)
... django.forms.models.ModelMultipleChoiceFieldTypedChoiceField(ChoiceField)
= lambda val: val 对选中的值进行一次转换
coerce
empty_value= ‘‘ 空值的默认值MultipleChoiceField(ChoiceField)
...TypedMultipleChoiceField(MultipleChoiceField)
= lambda val: val 对选中的每一个值进行一次转换
coerce
empty_value= ‘‘ 空值的默认值ComboField(Field)
=() 使用多个验证,如下:即验证最大长度20,又验证邮箱格式
fields
fields.ComboField(fields=[fields.CharField(max_length=20), fields.EmailField(),])MultiValueField(Field)
PS: 抽象类,子类中可以实现聚合多个字典去匹配一个值,要配合MultiWidget使用SplitDateTimeField(MultiValueField)
=None, 格式列表:[‘%Y--%m--%d‘, ‘%m%d/%Y‘, ‘%m/%d/%y‘]
input_date_formats
input_time_formats=None 格式列表:[‘%H:%M:%S‘, ‘%H:%M:%S.%f‘, ‘%H:%M‘]FilePathField(ChoiceField) 文件选项,目录下文件显示在页面中
=None, 正则匹配
path, 文件夹路径
match
recursive=False, 递归下面的文件夹
allow_files=True, 允许文件
allow_folders=False, 允许文件夹
required=True,
widget=None,
label=None,
initial=None,
help_text=‘‘GenericIPAddressField
=‘both‘, both,ipv4,ipv6支持的IP格式
protocol
unpack_ipv4=False 解析ipv4地址,如果是::ffff:192.0.2.1时候,可解析为192.0.2.1, PS:protocol必须为both才能启用SlugField(CharField) 数字,字母,下划线,减号(连字符)
...UUIDField(CharField) uuid类型
复制代码
RegexValidator验证器
from django.forms import Form from django.forms import widgets from django.forms import fields from django.core.validators import RegexValidator class MyForm(Form):
user = fields.CharField(
validators=[RegexValidator(r‘[1]+$‘, ‘请输入数字‘), RegexValidator(r‘^159[0-9]+$‘, ‘数字必须以159开头‘)],
)
自定义验证函数
import re from django.forms import Form from django.forms import widgets from django.forms import fields from django.core.exceptions import ValidationError # 自定义验证规则
def mobile_validate(value):
mobile_re = re.compile(r‘^(13[0-9]|15[012356789]|17[678]|18[0-9]|14[57])[0-9]{8}$‘)
ifnot mobile_re.match(value):
raise ValidationError(‘手机号码格式错误‘) #自定义验证规则的时候,如果不符合你的规则,需要自己发起错误 class PublishForm(Form):title </span>= fields.CharField(max_length=20<span style="color: #000000;">, min_length</span>=5<span style="color: #000000;">, error_messages</span>={<span style="color: #800000;">‘</span><span style="color: #800000;">required</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">标题不能为空</span><span style="color: #800000;">‘</span><span style="color: #000000;">, </span><span style="color: #800000;">‘</span><span style="color: #800000;">min_length</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">标题最少为5个字符</span><span style="color: #800000;">‘</span><span style="color: #000000;">, </span><span style="color: #800000;">‘</span><span style="color: #800000;">max_length</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">标题最多为20个字符</span><span style="color: #800000;">‘</span><span style="color: #000000;">}, widget</span>=widgets.TextInput(attrs={<span style="color: #800000;">‘</span><span style="color: #800000;">class</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">"</span><span style="color: #800000;">form-control</span><span style="color: #800000;">"</span><span style="color: #000000;">, </span><span style="color: #800000;">‘</span><span style="color: #800000;">placeholder</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">标题5-20个字符</span><span style="color: #800000;">‘</span><span style="color: #000000;">})) </span><span style="color: #008000;">#</span><span style="color: #008000;"> 使用自定义验证规则</span> phone = fields.CharField(validators=<span style="color: #000000;">[mobile_validate, ], error_messages</span>={<span style="color: #800000;">‘</span><span style="color: #800000;">required</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">手机不能为空</span><span style="color: #800000;">‘</span><span style="color: #000000;">}, widget</span>=widgets.TextInput(attrs={<span style="color: #800000;">‘</span><span style="color: #800000;">class</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">"</span><span style="color: #800000;">form-control</span><span style="color: #800000;">"</span><span style="color: #000000;">, </span><span style="color: #800000;">‘</span><span style="color: #800000;">placeholder</span><span style="color: #800000;">‘</span>: u<span style="color: #800000;">‘</span><span style="color: #800000;">手机号码</span><span style="color: #800000;">‘</span><span style="color: #000000;">})) email </span>= fields.EmailField(required=<span style="color: #000000;">False, error_messages</span>={<span style="color: #800000;">‘</span><span style="color: #800000;">required</span><span style="color: #800000;">‘</span>: u<span style="color: #800000;">‘</span><span style="color: #800000;">邮箱不能为空</span><span style="color: #800000;">‘</span>,<span style="color: #800000;">‘</span><span style="color: #800000;">invalid</span><span style="color: #800000;">‘</span>: u<span style="color: #800000;">‘</span><span style="color: #800000;">邮箱格式错误</span><span style="color: #800000;">‘</span><span style="color: #000000;">}, widget</span>=widgets.TextInput(attrs={<span style="color: #800000;">‘</span><span style="color: #800000;">class</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">"</span><span style="color: #800000;">form-control</span><span style="color: #800000;">"</span>, <span style="color: #800000;">‘</span><span style="color: #800000;">placeholder</span><span style="color: #800000;">‘</span>: u<span style="color: #800000;">‘</span><span style="color: #800000;">邮箱</span><span style="color: #800000;">‘</span>}))</pre>
除了上面两种方式,我们还可以在Form类中定义钩子函数,来实现自定义的验证功能。
局部钩子
我们在Fom类中定义 clean_字段名() 方法,就能够实现对特定字段进行校验。
举个例子:
class LoginForm(forms.Form): username = forms.CharField( min_length=8, label="用户名", initial="张三", error_messages={ "required": "不能为空", "invalid": "格式错误", "min_length": "用户名最短8位" }, widget=forms.widgets.TextInput(attrs={"class": "form-control"}) ) ... # 定义局部钩子,用来校验username字段,之前的校验股则还在,给你提供了一个添加一些校验功能的钩子def clean_username(self): value = self.cleaned_data.get("username") if"666"in value: raise ValidationError("光喊666是不行的") else: return value
全局钩子
我们在Fom类中定义 clean() 方法,就能够实现对字段进行全局校验,字段全部验证完,局部钩子也全部执行完之后,执行这个全局钩子校验。
class LoginForm(forms.Form): ... password = forms.CharField( min_length=6, label="密码", widget=forms.widgets.PasswordInput(attrs={‘class‘: ‘form-control‘}, render_value=True) ) re_password = forms.CharField( min_length=6, label="确认密码", widget=forms.widgets.PasswordInput(attrs={‘class‘: ‘form-control‘}, render_value=True) ) ... # 定义全局的钩子,用来校验密码和确认密码字段是否相同,执行全局钩子的时候,cleaned_data里面肯定是有了通过前面验证的所有数据def clean(self): password_value = self.cleaned_data.get(‘password‘) re_password_value = self.cleaned_data.get(‘re_password‘) if password_value == re_password_value: return self.cleaned_data #全局钩子要返回所有的数据 else: self.add_error(‘re_password‘, ‘两次密码不一致‘) #在re_password这个字段的错误列表中加上一个错误,并且clean_data里面会自动清除这个re_password的值,所以打印clean_data的时候会看不到它 raise ValidationError(‘两次密码不一致‘)
应用Bootstrap样式
Django form应用Bootstrap样式简单示例:
<! DOCTYPE html > < html lang ="en" > < head > < meta charset ="UTF-8" > < meta http-equiv ="x-ua-compatible" content ="IE=edge" > < meta name ="viewport" content ="width=device-width, initial-scale=1" > < link rel ="stylesheet" href ="/static/bootstrap/css/bootstrap.min.css" > < title >login</title></head><body><div class="container"><div class="row"><form action="/login2/" method="post" novalidate class="form-horizontal"> {% csrf_token %} <div class="form-group"><label for="{{ form_obj.username.id_for_label }}" class="col-md-2 control-label">{{ form_obj.username.label }}</label><div class="col-md-10"> {{ form_obj.username }} <span class="help-block">{{ form_obj.username.errors.0 }}</span></div></div><div class="form-group"><label for="{{ form_obj.pwd.id_for_label }}" class="col-md-2 control-label">{{ form_obj.pwd.label }}</label><div class="col-md-10"> {{ form_obj.pwd }} <span class="help-block">{{ form_obj.pwd.errors.0 }}</span></div></div><div class="form-group"><label class="col-md-2 control-label">{{ form_obj.gender.label }}</label><div class="col-md-10"><div class="radio"> {% for radio in form_obj.gender %} <label for="{{ radio.id_for_label }}"> {{ radio.tag }}{{ radio.choice_label }} </label> {% endfor %} </div></div></div><div class="form-group"><div class="col-md-offset-2 col-md-10"><button type="submit" class="btn btn-default">注册</button></div></div></form></div></div><script src="/static/jquery-3.2.1.min.js"></script>
<script src="/static/bootstrap/js/bootstrap.min.js"></script>
</body>
</html>
批量添加样式
可通过重写form类的init方法来实现。
class LoginForm(forms.Form): username = forms.CharField( min_length=8, label="用户名", initial="张三", error_messages={ "required": "不能为空", "invalid": "格式错误", "min_length": "用户名最短8位" } ...</span><span style="color: #0000ff;">def</span> <span style="color: #800080;">__init__</span>(self, *args, **<span style="color: #000000;">kwargs): super(LoginForm, self).</span><span style="color: #800080;">__init__</span>(*args, **<span style="color: #000000;">kwargs) </span><span style="color: #0000ff;">for</span> field <span style="color: #0000ff;">in</span><span style="color: #000000;"> iter(self.fields): self.fields[field].widget.attrs.update({ </span><span style="color: #800000;">‘</span><span style="color: #800000;">class</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">form-control</span><span style="color: #800000;">‘</span><span style="color: #000000;"> })</span></pre>
简单写一个小项目:book表的添加和数据展示
views.py内容如下:
from django.shortcuts import render,HttpResponse,redirect from app01 import models from django import forms # Create your views here.class BookForm(forms.Form):
title = forms.CharField(
max_length=16,
label=‘书名:‘,
initial=‘zhang‘,
# widget = forms.widgets.PasswordInput(attrs={‘class‘: ‘form-control‘},render_value=True),
widget = forms.widgets.TextInput(attrs={‘class‘: ‘form-control‘},),) </span><span style="color: #008000;">#</span><span style="color: #008000;"> title2 = forms.CharField(</span> <span style="color: #008000;">#</span><span style="color: #008000;"> max_length=16,</span> <span style="color: #008000;">#</span><span style="color: #008000;"> label=‘书名:‘,</span> <span style="color: #008000;">#</span><span style="color: #008000;"> initial=‘zhang‘,</span> <span style="color: #008000;">#</span><span style="color: #008000;"> # widget = forms.widgets.PasswordInput(attrs={‘class‘: ‘form-control‘},render_value=True),</span> <span style="color: #008000;">#</span><span style="color: #008000;"> widget=forms.widgets.TextInput(attrs={‘class‘: ‘form-control‘}, ),</span> <span style="color: #008000;">#
sex = forms.ChoiceField(
choices= (
( ‘ 1 ‘, ‘ 男 ‘ ),
( ‘ 2 ‘, ‘ 女 ‘ ),
)
,
label= ‘ 性别: ‘ ,
# widget=forms.widgets.RadioSelect(),
# widget=forms.widgets.RadioSelect(),
# widget=forms.widgets.SelectMultiple(attrs={‘class‘:‘form-control‘}),
widget=forms.widgets.Select(attrs={ ‘ class ‘: ‘ form-control ‘ }),
# widget=forms.widgets.CheckboxInput(),
# widget=forms.widgets.CheckboxSelectMultiple(),
)
publishDate = forms.DateField(
label= ‘ 出版日期: ‘ ,
widget=forms.widgets.TextInput(attrs={ ‘ type ‘: ‘ date ‘, ‘ class ‘: ‘ form-control ‘ }),
)
price= forms.DecimalField(
max_digits=5 ,
decimal_places=2 ,
label= ‘ 书籍的价格: ‘ ,
widget=forms.widgets.NumberInput(attrs={ ‘ class ‘: ‘ form-control ‘ }
))
</span><span style="color: #008000;">#</span><span style="color: #008000;"> publish = forms.ModelChoiceField(</span>
<span style="color: #008000;">#</span><span style="color: #008000;"> label=‘出版社:‘,</span>
<span style="color: #008000;">#</span><span style="color: #008000;"> queryset=models.Publish.objects.all(),</span>
<span style="color: #008000;">#</span><span style="color: #008000;"> widget=forms.widgets.Select(attrs={‘class‘: ‘form-control‘}</span>
<span style="color: #008000;">#</span><span style="color: #008000;"> ))</span>
publish_id =<span style="color: #000000;"> forms.ChoiceField(
label</span>=<span style="color: #800000;">‘</span><span style="color: #800000;">出版社:</span><span style="color: #800000;">‘</span><span style="color: #000000;">,
widget</span>=forms.widgets.Select(attrs={<span style="color: #800000;">‘</span><span style="color: #800000;">class</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">form-control</span><span style="color: #800000;">‘</span><span style="color: #000000;">}
))
authors </span>=<span style="color: #000000;"> forms.ModelMultipleChoiceField(
queryset</span>=<span style="color: #000000;">models.Author.objects.all(),
widget </span>= forms.widgets.SelectMultiple(attrs={<span style="color: #800000;">‘</span><span style="color: #800000;">class</span><span style="color: #800000;">‘</span>: <span style="color: #800000;">‘</span><span style="color: #800000;">form-control</span><span style="color: #800000;">‘</span><span style="color: #000000;">}
))
</span><span style="color: #0000ff;">def</span> <span style="color: #800080;">__init__</span>(self,*args, **<span style="color: #000000;">kwargs):
super().</span><span style="color: #800080;">__init__</span>(*args, **<span style="color: #000000;">kwargs)
self.fields[</span><span style="color: #800000;">‘</span><span style="color: #800000;">publish_id</span><span style="color: #800000;">‘</span>].choices = models.Publish.objects.values_list(<span style="color: #800000;">‘</span><span style="color: #800000;">pk</span><span style="color: #800000;">‘</span>,<span style="color: #800000;">‘</span><span style="color: #800000;">name</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
def
index(request):if request.method == ‘ GET ‘ :
form_obj = BookForm()
</span><span style="color: #0000ff;">return</span> render(request,<span style="color: #800000;">‘</span><span style="color: #800000;">index.html</span><span style="color: #800000;">‘</span>,{<span style="color: #800000;">‘</span><span style="color: #800000;">form_obj</span><span style="color: #800000;">‘</span><span style="color: #000000;">:form_obj})
</span><span style="color: #0000ff;">else</span><span style="color: #000000;">:
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(request.POST)
form_obj </span>=<span style="color: #000000;"> BookForm(request.POST)
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(form_obj.is_valid())
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(form_obj.errors)
</span><span style="color: #0000ff;">if</span><span style="color: #000000;"> form_obj.is_valid():
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(form_obj.cleaned_data)
authors_obj </span>= form_obj.cleaned_data.pop(<span style="color: #800000;">‘</span><span style="color: #800000;">authors</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
new_book_obj </span>= models.Book.objects.create(**<span style="color: #000000;">form_obj.cleaned_data)
new_book_obj.authors.add(</span>*<span style="color: #000000;">authors_obj)
</span><span style="color: #0000ff;">return</span> redirect(<span style="color: #800000;">‘</span><span style="color: #800000;">show</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
</span><span style="color: #0000ff;">else</span><span style="color: #000000;">:
</span><span style="color: #0000ff;">print</span><span style="color: #000000;">(form_obj.errors)
</span><span style="color: #0000ff;">return</span> render(request,<span style="color: #800000;">‘</span><span style="color: #800000;">index.html</span><span style="color: #800000;">‘</span>,{<span style="color: #800000;">‘</span><span style="color: #800000;">form_obj</span><span style="color: #800000;">‘</span><span style="color: #000000;">:form_obj})
def
show(request):
book_objs </span>=<span style="color: #000000;"> models.Book.objects.all()
</span><span style="color: #0000ff;">return</span> render(request,<span style="color: #800000;">‘</span><span style="color: #800000;">show.html</span><span style="color: #800000;">‘</span>,{<span style="color: #800000;">‘</span><span style="color: #800000;">book_objs</span><span style="color: #800000;">‘</span><span style="color: #000000;">:book_objs})
def
edit_book(request,n):
</span><span style="color: #0000ff;">return</span> HttpResponse(<span style="color: #800000;">‘</span><span style="color: #800000;">欢迎来到编辑页面</span><span style="color: #800000;">‘</span><span style="color: #000000;">)
def
delete_book(request,n):return HttpResponse( ‘ 欢迎来到删除页面 ‘)
内容总结
以上是互联网集市为您收集整理的django form 和modelform全部内容,希望文章能够帮你解决django form 和modelform所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。