forms组件补充:

forms组件的三个字段:ChoiceField, ModelChoiceField & ModelMultipleChoiceField

# forms组件:ChoiceField,ModelChoiceField,ModelMultipleChoiceField:这三个可用于渲染 <select> 标签

gender = forms.ChoiceField(choices=((1,"男"),(2,"女")))  # 不与数据库打交道时用 ChoiceField; 语法:forms.ChoiceField(choices=(一个一个的元组))

# 和数据库打交道:
# 单选用ModelChoiceField:
publish = forms.ModelChoiceField(queryset=Publish.objects.all()) # 语法:forms.ModelChoiceField(queryset=QuerySet) # 多选用ModelMultipleChoiceField:
author = forms.ModelMultipleChoiceField(queryset=Author.objects.all()) # 语法:forms.ModelMultipleChoiceField(queryset=QuerySet)

ModelForms 组件:

ModelForms组件的作用:验证字段、渲染标签和与数据库交互

from django import forms
from django.forms import widgets class BookForm(forms.ModelForm):
class Meta:
model = Book # 这句代码的含义:把Book这张model表能够当成 form组件表去使用;同时 Book 这张model表和 BookForm 表一一对应
fields = "__all__" # forms 组件表所使用的字段
labels = { # 给字段添加 label
"title":"书籍名称",
"price":"价格"
}
widgets = { # 给字段添加 widgets
"title":widgets.TextInput(attrs={"class":"form-control"}),
"price":widgets.TextInput(attrs={"class":"form-control"}),
"date":widgets.TextInput(attrs={"class":"form-control","type":"date"}), # date类型的数据要在 .TextInput(attrs={"type":"date"}) 中 加上 attrs={"type":"date"}
"publish":widgets.Select(attrs={"class":"form-control"}), # 单选框要用 Select
"authors":widgets.SelectMultiple(attrs={"class":"form-control"}) # 多选框要用 SelectMultiple
}
error_messages = { # 为字段添加错误信息
"title":{"required":"不能为空"},
"price":{"required":"不能为空"},
} # 添加书籍信息
def addbook(request):
if request.method == "POST":
form = BookForm(request.POST) # 前端传过来的书籍信息(在request.POST中)传入 BookForm 进行验证
if form.is_valid(): # ModelForm 拥有 Form组件的方法 # 验证 form 是否合法
form.save() # form.save() 就是把该记录保存到 Book 这张model表中; # 因为 BookForm 和 Book 是对应关系,所以 save()时能直接存到 Book 表中 return redirect("/books/") form = BookForm() # 通过 BookForm 就能把 Book 这张model表当 Form表去使用 return render(request,"addbook.html",{"form":form}) # 把 form 传入前端,直接渲染 # 编辑书籍信息
def editbook(request,edit_book_id):
edit_book_obj = Book.objects.filter(pk=edit_book_id).first() if request.method == "POST":
form = BookForm(request.POST,instance=edit_book_obj)
if form.is_valid:
form.save() # 此时 .save()是 update 操作
"""
当 BookForm()中没有 instance= xx 时, form.save()是 create 操作;当 BookForm()中有 instance=obj 时,此时 form.save()是update 操作,并且是将 request.POST 中的数据更新到 前面的 instance=obj 这个对象中
"""
return redirect("/books/") form = BookForm(instance=edit_book_obj) # 拿 edit_book_obj 这个所要编辑的书籍对象,放入 BookForm中实例化得到 form,此时form传入前端渲染时,能把 所要编辑的书籍信息直接显示出来:<input>,<select>的value值、selected return render(request,"editbook.html",{"form":form}) """
model表中的 CharField,DateField,EmailField等等,只有在涉及到 ModelForm 的时候才有意义; ModelForm会让model表按照各自的 Field类型转化成相应的 forms 组件
"""

ModelForm组件和forms组件补充的更多相关文章

  1. forms组件补充与ModelForm简单使用与cookie与session

    目录 forms组件钩子函数 forms组件字段参数 字段参数 validators详解 choices详解 widget详解 forms组件字段类型 ModelForm简单使用 cookie与ses ...

  2. Django-多对多关系的三种创建方式-forms组件使用-cookie与session-08

    目录 表模型类多对多关系的三种创建方式 django forms 组件 登录功能手写推理过程 整段代码可以放过来 forms 组件使用 forms 后端定义规则并校验结果 forms 前端渲染标签组件 ...

  3. 多对多第三张表的创建方式 和 forms组件的使用

    目录 一.多对多第三张表的创建 1. 全自动方式 (1)实现代码 (2)优点和不足 2. 纯手撸方式(了解) (1)实现代码 (2)优点和不足 3. 半自动方式(推荐使用) (1)实现代码 (2)优点 ...

  4. Python-S9—Day85-ORM项目实战之forms组件以及Modelform补充、跨域请求及应用

    01 forms组件补充1 02 forms组件补充2 03 ModelForm回顾 04 浏览器的历史 05 jsonop实现跨域请求 06 jsonop实现跨域请求2 07 jsonop实现跨域请 ...

  5. Django基础之forms组件中的ModelForm组件

    Django的model form组件 这是一个神奇的组件,通过名字我们可以看出来,这个组件的功能就是把model和form组合起来,先来一个简单的例子来看一下这个东西怎么用:比如我们的数据库中有这样 ...

  6. Django框架的forms组件与一些补充

    目录 一.多对多的三种创建方式 1. 全自动 2. 纯手撸(了解) 3. 半自动(强烈推荐) 二.forms组件 1. 如何使用forms组件 2. 使用forms组件校验数据 3. 使用forms组 ...

  7. python 全栈开发,Day78(Django组件-forms组件)

    一.Django组件-forms组件 forms组件 django中的Form组件有以下几个功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显 ...

  8. Django组件——forms组件

    一.校验字段功能 通过注册用户这个实例来学习校验字段功能. 1.模型:models.py from django.db import models # Create your models here. ...

  9. Django学习之八:forms组件【对form舒心了】

    目录 Django forms组件 bound and unbound form instance forms渲染有关 隐藏一个字段,不渲染它 form 校验 form类 ModelForm 利用Mo ...

随机推荐

  1. 如何移除EditText自动焦点

    <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_cont ...

  2. 移动端如何定义字体font-family

    移动端如何定义字体font-family 中文字体使用系统默认即可,英文用Helvetica /* 移动端定义字体的代码 */ body{font-family:Helvetica;} 参考<移 ...

  3. win7+idea+maven搭建spark源码阅读环境

    1.参考. 利用IDEA工具编译Spark源码(1.60~2.20) https://blog.csdn.net/He11o_Liu/article/details/78739699 Maven编译打 ...

  4. 洛谷 P3388 【模板】割点

    题目背景 割点 题目描述 给出一个n个点,m条边的无向图,求图的割点. 输入输出格式 输入格式: 第一行输入n,m 下面m行每行输入x,y表示x到y有一条边 输出格式: 第一行输出割点个数 第二行按照 ...

  5. pjax

    下载地址: https://github.com/defunkt/jquery-pjax/find/master 使用方法: 0.先引入jquery和jquery.pjax.js 1.父页面定义区域d ...

  6. CRegKey

    1.简介 CRegKey提供了对系统注册表的操作方法,通过CRegKey类,可以方便的打开注册表的某个分支或子键(CRegKey::Open),可以方便的修改一个键的键值(CRegKey::SetVa ...

  7. xamarin.forms 绑定页面里指定元素的某个属性值

    {Binding Source={x:Reference elementName}, Path=BindingContext.propertyname, Mode=OneWay} elementNam ...

  8. Less用法注意事项

    (1)引入顺序 引入你的 .less 样式文件的时候要设置 rel 属性值为 “stylesheet/less”: <link rel="stylesheet/less" t ...

  9. docker centos7 配置和宿主机同网段IP

    docker centos7 配置和宿主机同网段IP 1.安装brctl 命令 # yum -y install bridge-utils 2.编辑网卡配置文件 # vi ifcfg-eno16777 ...

  10. promise的简单使用

    var p = new Promise(function (resolve,reject) { /*setTimeout(function () { resolve('success') },3000 ...