https://www.cnblogs.com/liwenzhou/p/8747872.html

1. form组件的介绍

之前web开发的模式,以注册为例:
  1. 要有一个注册的页面,页面里面要有form表单 --> 生成HTML代码
  2. form表单要能提交数据到后端,后端要做有效性校验 --> 数据有效性校验
  3. 要把校验的提示信息展示在页面上 --> 校验信息返回并展示,保存原来填写的内容

关于校验:
  1. 前端通过JS代码做校验 --> 最好有
  2. 后端做校验 --> 必须要有(因为前端的校验可以被跳过)

2. form组件的用法
  1. from django import forms
  2, 定义一个form类
    class RegForm(forms.Form):
    user = forms.CharField()
    pwd = forms.CharField()
    email = forms.EmailField()
  生成HTML:
  3. 实例化一个form对象, 传递到模板语言中
  4. 在目标语言中调用form对象的响应方法和属性

三种方式:
1. {{ form_obj.as_p }}
2. 单独写
{{ form_obj.pwd.label }}
{{ form_obj.pwd }}

做校验:
1. form_obj = RegForm(request.POST)
2. form_obj.is_valid()

内置的正则校验器的使用
mobile = forms.CharField(
  label="手机",
  # 自己定制校验规则
  validators=[
  RegexValidator(r'^[0-9]+$', '手机号必须是数字'),
  RegexValidator(r'^1[3-9][0-9]{9}$', '手机格式有误')
  ],
  widget=widgets.TextInput(attrs={"class": "form-control"}),
  error_messages={
  "required": "该字段不能为空",
  }
)

重写__init__方法,动态获取数据库数据:

 def __init__(self,*args,**kwargs):
     super().__init__(*args,**kwargs)
     self.fields["......"].widgets.choice = models.xxxx.objects.all().value_list(xxx)

form表单验证流程

  1、正则表达式验证

  2、clean_name()方法

  3、clean()方法验证

整体验证方法(验证两次密码是否一致):

  

 from django import forms
 from django.forms import fields
 from django.core.exceptions import ValidationError,NON_FIELD_ERRORS

 class Test(forms.Form):
     password = fields.CharField(
         label="密码",
         min_length=6,
         max_length=32,
         required=True,
         error_messages={
             "required":"不能为空",
             "min_length":"最少为6位",
             "max_length":"最长为32位"
         }
     )
     re_pwd = fields.CharField(
         label="确认密码",
         min_length=6,
         max_length=32,
         required=True,
         error_messages={
             "required": "不能为空",
             "min_length": "最少为6位",
             "max_length": "最长为32位"
         }
     )
     def clean(self):
         try:
             v1 = self.cleaned_data["password"]
             v2 = self.cleaned_data["re_pwd"]
         except:
             return

         if v1 == v2:
             pass
         else:
             raise ValidationError("密码不一致")

 def test(request):
     if request.method == "GET":
         obj = Test()
         return render(request,"test.html",locals())
     else:
         obj = Test(request.POST)
         if obj.is_valid():
             return HttpResponse("success")
         else:
             return render(request,"test.html",locals())
 <form method="post" action="/personal_web/test" novalidate>
     {% csrf_token %}
     <div>{{ obj.password.label }}{{ obj.password }}{{ obj.password.errors.0 }}{{ obj.non_field_errors.0 }}</div>
     <div>{{ obj.re_pwd.label }}{{ obj.re_pwd }}{{ obj.re_pwd.errors.0 }}{{ obj.non_field_errors.0 }}</div>
     <div><input type="submit"></div>
 </form>

四、ModelForm

 class BookForm(forms.ModelForm):
     class Meta:
         model = models.Book
         fields = "__all__"      #还可以添加很多参数,如label、message_errors、widgits

 def add(request):
     if request.method == "POST":
         form = BookForm(request.POST)
         if form.is_valid():
             form.save()
             return ......        

     form = BookForm()
     return .....

 def edit(request):

     obj = models.Book.objects.filter(pk=1),first()

     if request.method == "POST":
         form = BookForm(request.POST,instance=obj)
         if form.is_valid():
             form.save()
             return ......        

     form = BookForm(instance=obj)
     return .....

Django之form表单的更多相关文章

  1. Django的form表单

    html的form表单 django中,前端如果要提交一些数据到views里面去,需要用到 html里面的form表单. 例如: # form2/urls.py from django.contrib ...

  2. Django 11 form表单(状态保持session、form表单及注册实现)

    Django 11 form表单(状态保持session.form表单及注册实现) 一.状态保持 session 状态保持 #1.http协议是无状态的:每次请求都是一次新的请求,不会记得之前通信的状 ...

  3. 转载:Django之form表单

    转载: 一.使用form类创建一个表单 先定义好一个RegForm类: forms.py from django import forms # 导入forms类 class NameForm(form ...

  4. Django--分页器(paginator)、Django的用户认证、Django的FORM表单

    分页器(paginator) >>> from django.core.paginator import Paginator >>> objects = ['joh ...

  5. django之form表单验证

    django中的Form一般有两种功能: 输入html 验证用户输入 #!/usr/bin/env python # -*- coding:utf- -*- import re from django ...

  6. django中form表单的提交:

    一,关于表单: 表单在百度百科的解释:   表单在网页中主要负责数据采集功能.一个表单有三个基本组成部分: 表单标签:这里面包含了处理表单数据所用CGI程序的URL以及数据提交到服务器的方法. 表单域 ...

  7. Day19 Django之Form表单验证、CSRF、Cookie、Session和Model操作

    一.Form表单验证 用于做用户提交数据的验证1.自定义规则 a.自定义规则(类,字段名==html中的name值)b.数据提交-规则进行匹配代码如下: """day19 ...

  8. Django的form表单之文件上传

    在生成input标签的时候可以指定input标签的类型为file类型 <!DOCTYPE html> <html lang="en"> <head&g ...

  9. 【django之form表单】

    一.构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method=&qu ...

  10. Django 提交 form 表单(使用sqlite3保存数据)

    优化 提交 form 表单,https://www.cnblogs.com/klvchen/p/10608143.html 创建数据库的字段,在 models.py 中添加 from django.d ...

随机推荐

  1. 一文搞懂Raft算法

      raft是工程上使用较为广泛的强一致性.去中心化.高可用的分布式协议.在这里强调了是在工程上,因为在学术理论界,最耀眼的还是大名鼎鼎的Paxos.但Paxos是:少数真正理解的人觉得简单,尚未理解 ...

  2. Player启动时提示 "System.InvalidOperationException:无法加载计数器名称数据

    问题 播放器意外断电重启后可能导致Player启动时报错,提示如下: 原因 这个提示一般指 Universal Player 找不到或无法设置一个Windows Performance Monitor ...

  3. spark-MLlib之协同过滤ALS

    协同过滤与推荐   协同过滤是一种根据用户对各种产品的交互与评分来推荐新产品的推荐系统技术.   协同过滤引入的地方就在于它只需要输入一系列用户/产品的交互记录:   无论是显式的交互(例如在购物网站 ...

  4. instanceof关键字的理解

    instanceof,两个单词组成,instance of,意为, "… 是 …的实例". 本身包含null值的判断.但是有不少人,先来个 obj != null,然后来个 obj ...

  5. Python——Pycharm基本设置

    一.,模板(加入中文UTF-8) #!/usr/bin/env python # -*- coding:utf-8 -*- 设置方法:file->settings->Editor-> ...

  6. QT出现应用程序无法正常启动0xc000007b的错误

    最近做了一个成绩管理系统,打包好后,运行他的exe可执行文件时,出现了如下图的错误提示: 在网上查阅了很多资料,其中有篇文章给了我很大的启示和帮助,文章地址http://www.cnblogs.com ...

  7. tomcat配置详解

    Tomcat Server的结构图如下: 该文件描述了如何启动Tomcat Server <Server>    <Listener />    <GlobaNaming ...

  8. Java【第四篇】基本语法之--循环

    循环语句功能 在循环条件满足的情况下,反复执行特定代码 循环语句的四个组成部分 初始化部分(init_statement)循环条件部分(test_exp) 循环体部分(body_statement) ...

  9. SignarL服务器端发送消息给客户端的几种情况

    一.所有连接的客户端 Clients.All.addContosoChatMessageToPage(name, message); 二.只发送给呼叫的客户端(即触发者) Clients.Caller ...

  10. vue常用手册

    1.搭建vue的开发环境: 1.必须要安装node.js 2.安装vue的脚手架工具 官方命令行工具 npm install --global vue-cli 3.新建项目 vue init webp ...