表单

HTML中的表单:

从前端来说,表单就是用来将数据提交给服务器的,不管后台使用的是django还是php等其他的语言。只要把input标签放在form标签中,然后再添加一个提交的按钮,就可以将input标签中对应的值提交给服务器。

Django中的表单:

Django中的表单丰富了传统的html语言中的表单,在Django中的表单主要有以下两个作用:
(1)渲染表单模板
(2)表单验证数据是否合法。

Django中表单使用流程:

首先我们以一个留言板为例。简单的介绍一下Django中表单的使用流程。
(1)首先在项目中的APP中新建一个python文件forms.py,在forms.py文件中就可以定义我们的表单模板了。示例代码如下:
from django import forms

class MessageBoard(forms.Form):
title = forms.CharField(max_length=100, min_length=2, label='标题', error_messages={'invalid': '您输入形式不合法'})
content = forms.CharField(widget=forms.Textarea, label='内容')
email = forms.EmailField(label='邮箱')
reply = forms.BooleanField(required=False, label='是否需要回复')
(2)在views.py文件中,应用form表单,进行验证数据是否合法,使用GET请求返回定义的Django模板页面;采用POST请求,如果验证数据合法,就获取提交上来的数据,否者的话,就返回HttpResponse提示用户失败。示例代码如下:
from django.shortcuts import render
from django.http import HttpResponse
from django.views import View
from .forms import MessageBoard
from django.forms.utils import ErrorDict class MessageBoard_view(View): def get(self,request):
form = MessageBoard()
return render(request, 'front/index.html', context={'form': form}) def post(self,request):
form = MessageBoard(request.POST)
if form.is_valid():
title = form.cleaned_data.get('title')
content = form.cleaned_data.get('content')
email = form.cleaned_data.get('email')
reply = form.cleaned_data.get('reply')
print(title)
print(content)
print(email)
print(reply)
return HttpResponse('success')
else:
# print(type(form.errors))
# <class 'django.forms.utils.ErrorDict'> # 打印出显示的错误信息,字典形式显示
print(form.errors.get_json_data())
return HttpResponse('Fail')
(3)在index.html中将Django表单进行渲染。在table标签中对我们实例化的form对象使用as_table方法就可以将我们定义在forms.py文件中各个字段渲染成table表中的tr,td标签进行显示,在form标签中写入一个submit的input标签就可以将我们在浏览器中输入的信息采用POST请求,提交至后台,示例代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Django中表单的使用流程</title>
</head>
<body>
<form action="" method="post">
<table>
{{ form.as_table }}
<tr>
<td></td>
<td><input type="submit" value="提交"></td>
</tr>
</table>
</form>
</body>
</html>
(4)在APP中创建文件urls.py文件,进行视图与url之间的映射,示例代码如下:
from django.urls import path
from.views import MessageBoard_view app_name = 'front' urlpatterns = [
path('', MessageBoard_view.as_view(), name='index'),
]
(5)在项目中的urls.py中进行主url与子url之间的映射,示例代码如下:
from django.urls import path, include

urlpatterns = [
path('front/', include('front.urls')),
]

118.django中表单的使用方式的更多相关文章

  1. Django中表单的用法深探

    [转载说明:原文排版不是很好,为方便阅读,改进了排版] django的表单设计真的很棒,涉及非常多的功能,今天介绍django较为主流的几种表单使用方法.注:本文中表单与form通用.模型与model ...

  2. django中表单处理

    在web端与后端交互时,我们除了使用html原生的form标签,还可以使用django自带的表单. Django 提供广泛的工具和库来帮助你构建表单来接收网站访问者的输入,然后处理以及响应输入. HT ...

  3. Django表单介绍

    HTML 表单 在HTML中,表单是<form>...</form> 之间元素的集合,它们允许访问者输入文本.选择选项.操作对象和控制等等,然后将信息发送回服务器. 某些表单的 ...

  4. python3之Django表单(一)

    1.HTML中的表单 在HTML种,表单是在<form>...</form>种的元素,它允许用户输入文本,选择选项,操作对象等,然后发送这些数据到服务器 表单元素允许用户在表单 ...

  5. 第四章:Django表单 - 3:Django表单字段汇总

    Field.clean(value)[source] 虽然表单字段的Field类主要使用在Form类中,但也可以直接实例化它们来使用,以便更好地了解它们是如何工作的.每个Field的实例都有一个cle ...

  6. 关于struts2中表单提交时,中文乱码问题的解决

    http://blog.csdn.net/hjw506848887/article/details/8966194 今天写项目时,突然遇到了struts2中表单提交的中文乱码问题,调了好久就是不知道答 ...

  7. HTML5中表单验证的8种方法(转)

    在深人探讨表单验证之前,让我们先思考一下表单验证的真实含义.就其核心而言,表单验证是一套系统,它为终端用户检测无效的控件数据并标记这些错误.换言之,表单验证就是在表单提交服务器前对其进行一系列的检查并 ...

  8. form表单的提交方式

    开发中表单提交是很常见的,表单的提交方式也多种方式. 1.使用submit按钮提交表单  <input type="submit"/> <!DOCTYPE htm ...

  9. python 全栈开发,Day108(客户管理之权限控制,客户管理之动态"一级"菜单,其他应用使用rbac组件,django static文件的引入方式)

    一.客户管理之权限控制 昨天的作业,有很多不完善的地方 下载代码,基本实现权限验证 https://github.com/987334176/luffy_permission/archive/v1.2 ...

随机推荐

  1. SpringBoot与Mybatis-plus整合,代码生成mvc层

    一.添加pom依赖 <!-- mysql驱动 --> <dependency> <groupId>mysql</groupId> <artifac ...

  2. EOS主网搭建教程--&&--搭建节点--&&--搭建mongodb数据库

    EOS主网搭建教程: 1.git clone https://github.com/EOS-Mainnet/eos.git --recursive 2.cd eos 3.git tag (查看有哪些分 ...

  3. frp 配置

    前言 对于没有公网 IP 的内网用户来说,远程管理或在外网访问内网机器上的服务是一个问题. 今天给大家介绍一款好用内网穿透工具 FRP,FRP 全名:Fast Reverse Proxy.FRP 是一 ...

  4. 【PAT甲级】1024 Palindromic Number (25 分)

    题意: 输入两个正整数N和K(N<=1e10,k<=100),求K次内N和N的反置相加能否得到一个回文数,输出这个数和最小的操作次数. trick: 1e10的数字相加100次可能达到1e ...

  5. scrapy shell中遇到的坑

    如果直接scrapy shell +网址  然后发现返回200 但是request和response的网址不同,那么可以使用百度短网址 https://dwz.cn/ 进行缩短.这样一般就能解决问题

  6. linux服务器上安装jdk8的两种方法

    这里介绍两种安装方式: yum安装(力荐) 从官网下载包安装 获得一台linux服务器 要在linux下安装jdk,首先你得先有一台linux服务器,虚拟机或者租一台都可以   yum安装jdk 在l ...

  7. js实现超范围的数相加

    在js中能表示的最大安全整数是 9007199254740991,可以用API Number.MAX_SAFE_INTEGER 看一下  超出范围就会发生精度丢失,像这样 解决方法: 相当于一个字符串 ...

  8. 移动端300毫秒事件响应延迟解决方法[fastclick]

    vue-cli[2.x]中: 安装 npm install fastclick --save 使用: 在main.js中 :先 import fastClick from 'fastclick' 然后 ...

  9. MySql数据库慢查询

    一.什么是数据库慢查询? 数据库慢查询,就是查询时间超过了我们设定的时间的语句. 可以查看设定的时间: 默认的设定时间是10秒.也可以自己根据实际项目设定. set long_query_time=0 ...

  10. node服务端口被占用

    今天在输入node .\app.js启动api接口时出现了以下报错: 出现这个报错说明端口被占用:Error: listen EADDRINUSE: address already in use :: ...