views.py

  1. from django.shortcuts import render,HttpResponse
  2. from django import forms
  3. import json
  4. import re
  5. from django.core.exceptions importValidationError
  6. # Create your views here.
  7. def mobile_validate(value):
  8. mobile_re = re.compile(r'^(13[0-9]|15[012356789]|17[678]|18[0-9]|14[57])[0-9]{8}$')
  9. ifnot mobile_re.match(value):
  10. raiseValidationError('手机号码格式错误')
  11. classInputForm(forms.Form):
  12. # 下面使用的变量名必须和html中input标签的name值相同
  13. # forms 的字段类型包括:IntegerField,CharField,URLField,EmailField,DateField等,但是没有手机号
  14. # required=True表示对输入做验证
  15. # error_messages 自定制提示信息
  16. username = forms.CharField(required=True, error_messages={'required':'用户名不能为空'})
  17. password = forms.CharField(required=True,
  18. min_length=8,
  19. max_length=20,
  20. error_messages={'required':'密码不能为空','min_length':'至少6位',
  21. 'max_length':'至多10位'}
  22. )
  23. num = forms.IntegerField(error_messages={'required':'不能为空','invalid':'必须是数字'})
  24. # 自定制验证方法关键就是参数validators,和自己的函数关联起来
  25. phone = forms.CharField(validators=[mobile_validate,],)
  26. # django给标签加sytle,关键参数widget ,forms.TextInput 表示生成type="text"的input标签,改成Textarea则生成<textarea>标签
  27. test = forms.CharField(widget=forms.TextInput(attrs={'class':'in_tmp'}))
  28. choice =(
  29. (1,'北京'),
  30. (2,'上海')
  31. )
  32. t_choice = forms.IntegerField(widget=forms.Select(choices=choice))
  33. def login(request):
  34. if request.POST:
  35. objPost =InputForm(request.POST)
  36. ret = objPost.is_valid()
  37. if ret:
  38. print(objPost.clean())
  39. # else:
  40. # # from django.forms.utils import ErrorDict
  41. # print(type(objPost.errors),objPost.errors.as_json())
  42. return render(request,'login.html',{'data': objPost})
  43. else:
  44. objGet =InputForm()
  45. return render(request,'login.html',{'data': objGet})
login.html
  1. <!DOCTYPE html>
  2. <htmllang="en">
  3. <head>
  4. <metacharset="UTF-8">
  5. <title>Title</title>
  6. <style>
  7. .error-msg{
  8. color:red;
  9. }
  10. .in_tmp{
  11. border:1px solid #6a34ff ;
  12. }
  13. </style>
  14. </head>
  15. <body>
  16. <formaction="/login/"method="POST">
  17. <div>
  18. <div>
  19. {{ data.username }}
  20. {% if data.errors.username %}
  21. <spanclass="error-msg">{{ data.errors.username.0 }}</span>
  22. {% endif %}
  23. </div>
  24. <div>
  25. {{ data.password }}
  26. {% if data.errors.password %}
  27. <spanclass="error-msg">{{ data.errors.password.0 }}</span>
  28. {% endif %}
  29. </div>
  30. <div>
  31. {{ data.num }}
  32. {% if data.errors.num %}
  33. <spanclass="error-msg">{{ data.errors.num.0 }}</span>
  34. {% endif %}
  35. </div>
  36. <div>
  37. {{ data.phone }}
  38. {% if data.errors.phone %}
  39. <spanclass="error-msg">{{ data.errors.phone.0 }}</span>
  40. {% endif %}
  41. </div>
  42. <div>
  43. {{ data.test }}
  44. {% if data.errors.test %}
  45. <spanclass="error-msg">{{ data.errors.test.0 }}</span>
  46. {% endif %}
  47. </div>
  48. <div>
  49. {{ data.t_choice }}
  50. {% if data.errors.t_choice %}
  51. <spanclass="error-msg">{{ data.errors.t_choice.0 }}</span>
  52. {% endif %}
  53. </div>
  54. <inputtype="submit"value="提交"/>
  55. </div>
  56. </form>
  57. </body>
  58. </html>
效果图:

 
select 标签显示数据库数据:

循序渐进PYTHON3(十三) --3-- DJANGO之FORM表单(为自动生成的HTML标签添加样式)的更多相关文章

  1. 循序渐进PYTHON3(十三) --2-- DJANGO之FORM表单(自动生成HTML标签和自定制提示信息)

    在上一次的代码上做出进一步修改,使之能在页面上显示自定制的报错信息,并且使用form自动创建标签的功能. views.py from django.shortcuts import render,Ht ...

  2. Django的form表单

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

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

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

  4. 转载:Django之form表单

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

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

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

  6. js模拟form表单提交数据, js模拟a标签点击跳转,避开使用window.open引起来的浏览器阻止问题

    js模拟form表单提交数据, js模拟a标签点击跳转,避开使用window.open引起来的浏览器阻止问题 js模拟form表单提交数据源码: /** * js模拟form表单提交 * @param ...

  7. 循序渐进Python3(十三) --0-- django之form表单

    django为我们提供了form表单验证功能,下面来学习一下: 武sir博客:http://www.cnblogs.com/wupeiqi/articles/5246483.html  创建了djan ...

  8. django之form表单验证

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

  9. django中form表单的提交:

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

随机推荐

  1. UVA129 暴力dfs,有许多值得学习的代码

    紫书195 题目大意:给一个困难的串,困难的串的定义就是里面没有重复的串. 思路:不需要重新对之前的串进行判重,只需要对当前的加入的字符进行改变即可. 因为是判断字典序第k个的字符串,所以要多一个全局 ...

  2. asp.net 权限管理系统

    asp.net webform ,基于组织机构.角色的权限管理系统. 网上找的,挺好.随拿来分享. https://bitbucket.org/zzhi/asp.net

  3. ios的app,有新版本时必须先更新。

    现在没时间整理,先把代码贴出来,以后再做详细的思路整理. 1 在AppController.mm的didFinishLaunchingWithOptions方法里面获取本地应用版本信息,保存起来. / ...

  4. Http跨域时候预检没通过的几种原因

    网上大多数涉及的原因(直接复制粘帖): CORS把HTTP请求分成两类,不同类别按不同的策略进行跨域资源共享协商. 1. 简单跨域请求. 当HTTP请求出现以下两种情况时,浏览器认为是简单跨域请求: ...

  5. SQL注入文件读取通过from for分页读取

    http://103.238.227.13:10088/?id=1 在读取文件的时候发现不能够一下子全部读取出来.经过百度学习了一下,看到别人使用from for说实在此前真不知道这操作. 先来看一下 ...

  6. Linux 内核同步之自旋锁与信号量的异同【转】

    转自:http://blog.csdn.net/liuxd3000/article/details/8567070 Linux 设备驱动中必须解决的一个问题是多个进程对共享资源的并发访问,并发访问会导 ...

  7. oc 与 swift 之间的桥接文件 (ProjectNmae-Bridging-Header.h) (ProjectNmae-Swift.h)

    oc 与 Swift 是2种不同的语言, oc代码只能写带oc文件里, Swift代码只能写在Swift文件里, 虽然2者不同语言, 但却能互相调用, 不过需要进行一下桥接, 就是下面的2个文件 (P ...

  8. 网站服务器压力Web性能测试(3):http_load:测试web服务器的吞吐量与负载

    1.http_load是国外一个博主写的一个基于Linux的性能测工具,小巧轻便,解压缩后不到100k,下载安装方法: wget https://acme.com/software/http_load ...

  9. 批量导出文件名 另存为bat文件

    @echo offdir /b *.* > 导出的文件名.txtexit

  10. 在ubuntu上配置LAMP架构

    1. 安装MySQL /* ubuntu默认进入系统是普通用户 所以在真实工作中,我们会得到root的授权. 所以我们需要用sudo做一切只有root才能完成的操作. */ [root@LAMP ~] ...