django框架的表单form的理解和用法-9
yuyutoo 2024-11-14 19:54 3 浏览 0 评论
表单呈现
在使用Django表单时,通常需要在HTML中呈现表单。为此,可以使用Django提供的一些内置标签和过滤器。
以下是一个基本的表单呈现示例:
<form method="post">
{% csrf_token %}
{{ form.as_p }}
<button type="submit">Submit</button>
</form>
在上面的代码中,我们首先使用{% csrf_token %}标签添加CSRF令牌以保护表单免受跨站点请求伪造攻击。然后,我们使用{{ form.as_p }}过滤器呈现整个表单,并将每个字段作为单独的段落呈现。最后,我们添加了一个提交按钮。
Django还提供了许多其他的表单呈现方式,例如使用as_table()或as_ul()过滤器将表单呈现为HTML表格或无序列表。您还可以使用自定义模板来完全控制表单的呈现方式。
表单处理
当用户提交表单时,表单数据将被发送到服务器并由Django视图函数处理。在处理表单之前,您可能需要执行一些验证或数据清理操作。这可以通过调用表单的is_valid()方法并检查其返回值来完成。
以下是一个处理表单的视图函数示例:
from django.shortcuts import render
from myapp.forms import ContactForm
def contact(request):
if request.method == 'POST':
form = ContactForm(request.POST)
if form.is_valid():
# 处理表单数据
name = form.cleaned_data['name']
email = form.cleaned_data['email']
message = form.cleaned_data['message']
# 发送邮件等其他逻辑...
return render(request, 'success.html')
else:
form = ContactForm()
return render(request, 'contact.html', {'form': form})
在上面的代码中,我们首先检查request.method是否为POST,如果是,则使用提交的数据创建一个新的表单实例。然后,我们调用form.is_valid()以验证表单,并获取清理后的数据字段(例如,使用form.cleaned_data['name']访问name字段)。最后,我们执行任何必要的业务逻辑并返回响应。
自定义表单字段
在某些情况下,您可能需要创建自定义表单字段来处理具有特殊要求的输入数据。这可以通过继承Django内置字段并添加自己的逻辑来完成。
以下是一个示例自定义表单字段:
from django import forms
class UsernameField(forms.CharField):
def to_python(self, value):
value = super().to_python(value)
if not value:
return ''
return value.lower()
def widget_attrs(self, widget):
attrs = super().widget_attrs(widget)
attrs['autocomplete'] = 'username'
return attrs
在上面的代码中,我们首先创建了一个名为UsernameField的自定义表单字段,它继承自Django内置的CharField。然后,我们覆盖了to_python()方法以将输入值转换为小写,并在输入为空时返回一个空字符串。最后,我们覆盖了widget_attrs()方法以添加一个自动完成属性。
表单样式
在呈现表单时,通常需要对字段进行样式化,以使其看起来更漂亮和易于使用。有许多CSS框架和库可以用于此目的,例如Bootstrap和Foundation。
以下是一个使用Bootstrap样式的表单示例:
<form method="post" class="form">
{% csrf_token %}
<div class="form-group">
{{ form.name.label_tag }}
{{ form.name }}
</div>
<div class="form-group">
{{ form.email.label_tag }}
{{ form.email }}
</div>
<div class="form-group">
{{ form.message.label_tag }}
{{ form.message }}
</div>
<button type="submit" class="btn btn-primary">Submit</button>
</form>
在上面的代码中,我们首先为表单添加了form类,并为每个表单字段创建了一个带有form-group类的包装器。然后,我们使用label_tag属性为每个字段添加标签,并使用默认的小部件呈现每个字段。
最后,我们添加了一个提交按钮,并使用btn和btn-primary类将其样式化为Bootstrap样式。这仅是一个示例,您可以根据需要自定义CSS类和样式。
Ajax表单提交
在某些情况下,您可能希望通过Ajax异步提交表单,而不是刷新整个页面。您可以使用jQuery或其他JavaScript库来执行此操作。
以下是一个使用jQuery提交表单的示例:
<form method="post" id="contact-form">
{% csrf_token %}
<div class="form-group">
{{ form.name.label_tag }}
{{ form.name }}
</div>
<div class="form-group">
{{ form.email.label_tag }}
{{ form.email }}
</div>
<div class="form-group">
{{ form.message.label_tag }}
{{ form.message }}
</div>
<button type="submit" class="btn btn-primary">Submit</button>
</form>
<script>
$(document).ready(function() {
$('#contact-form').submit(function(event) {
event.preventDefault();
var formData = $(this).serialize();
$.ajax({
url: '/contact/',
type: 'POST',
data: formData,
success: function(data) {
// 处理成功响应
},
error: function(jqXHR, textStatus, errorThrown) {
// 处理错误响应
}
});
});
});
</script>
在上面的代码中,我们首先为表单添加了一个id属性以便在JavaScript中引用它。然后,我们使用jQuery的submit()方法在表单提交时阻止默认行为,并使用serialize()方法将表单数据转换为字符串。最后,我们使用$.ajax()函数向服务器发送异步POST请求,并在成功或错误时处理响应。
内联表单
有时,您可能需要将表单呈现为内联样式,以便更好地适应页面布局。这可以通过添加一些CSS样式来实现。
以下是一个基本的内联表单示例:
<form method="post" class="form-inline">
{% csrf_token %}
<div class="form-group">
{{ form.name.label_tag }}
{{ form.name }}
</div>
<div class="form-group">
{{ form.email.label_tag }}
{{ form.email }}
</div>
<div class="form-group">
{{ form.message.label_tag }}
{{ form.message }}
</div>
<button type="submit" class="btn btn-primary">Submit</button>
</form>
在上面的代码中,我们为表单添加了form-inline类,并使用form-group和label类调整字段和标签的样式。
多部分表单
有时,您可能需要创建包含文件上传等功能的多部分表单。Django的MultiValueDict类提供了一种处理此类表单数据的方法。
以下是一个基本的多部分表单示例:
from django.http import HttpResponse
from django.shortcuts import render
def upload(request):
if request.method == 'POST':
files = request.FILES.getlist('file')
for f in files:
# 处理文件上传...
return HttpResponse('上传成功!')
return render(request, 'upload.html')
在上面的代码中,我们首先检查request.method是否为POST,如果是,则使用request.FILES.getlist()获取提交的文件列表。然后,我们可以遍历文件列表并执行任何必要的业务逻辑。
在HTML中,您需要添加enctype="multipart/form-data"属性以启用多部分表单上传:
<form method="post" enctype="multipart/form-data">
{% csrf_token %}
<div class="form-group">
<label for="file">选择文件:</label>
<input type="file" id="file" name="file" multiple>
</div>
<button type="submit" class="btn btn-primary">上传</button>
</form>
在上面的代码中,我们添加了一个类型为file的输入字段,并将multiple属性设置为允许选择多个文件。
相关推荐
- JavaWeb开发入门需要学哪些?看完你就懂了
-
目前,国内外信息化建设已经进入基于Web应用为核心的阶段,Java作为应用于网络的最好语言,前景无限看好。然而,就算用Java建造一个不是很烦琐的web应用,也不是件轻松的事情。那么,本文章就来详细说...
- Spring Boot 中如何实现通过Cookie来实现用户鉴权?
-
Cookie是存储在用户浏览器中的一小段数据,主要的作用是用来帮助Web服务器和客户端之间的通信。这段数据由服务端生成,然后通过HTTP的头部信息反馈给客户端,然后再后续的操作中客户端会自动将这些Co...
- Session和cookie笔记 session与cookie的关系
-
会话技术1.会话:一次会话中包含多次请求和响应。*一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止2.功能:在一次会话的范围内的多次请求间,共享数据3.方式:1.客户...
- 精读大型网站架构的技术细节:后端架构规整化Cookie和Session
-
Cookie和Session接口请求(HTTP请求)是无状态的,每次请求都是完全独立的。也就是说,在处理请求时,Web应用服务器无法得知这个请求是哪个用户发送的,无法跟踪上一次请求的状态。但是,有些时...
- 一文彻底搞懂Cookie、Session、Token到底是什么
-
一、Cookie洛:大爷,楼上322住的是马冬梅家吧?大爷:马都什么?夏洛:马冬梅。大爷:什么都没啊?夏洛:马冬梅啊。大爷:马什么没?夏洛:行,大爷你先凉快着吧。在了解这三个概念之前我们...
- Python常用的第三方包-Requests 5个常用python第三方库
-
在现代互联网时代,进行网络请求是开发人员经常需要处理的任务之一。Python的Requests包是一个强大而易于使用的工具,可以简化网络请求的过程,并提供了丰富的功能。本文将深入介绍如何使用Pytho...
- 干货 | REST-assured 获取日志到文件并结合 Allure 报告进行展示
-
使用Rest-assured集合Allure运行完用例之后,在生成的报告中只有断言信息,没有请求的日志信息。而当我们的用例失败时,特别是接口失败时,请求日志是分析原因的第一手资源。那如何将R...
- 前后端数据交互(四)——fetch 请求详解
-
fetch是XMLHttpRequest的升级版,使用js脚本发出网络请求,但是与XMLHttpRequest不同的是,fetch方式使用Promise,相比XMLHttpReques...
- 【0基础学爬虫】爬虫基础之网络请求库的使用
-
大数据时代,各行各业对数据采集的需求日益增多,网络爬虫的运用也更为广泛,越来越多的人开始学习网络爬虫这项技术,K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章,为实现从易到难全方位覆盖,特设【0基础学爬...
- ASP.NET MVC开发日常一:SessionID更新
-
在MVCWeb开发中临时存储数据一般会用到Session,Cookie,ViewBag,ViewData,TempData。每个的使用场景是不同,具体区别有空再补上。Session数据最敏感,最需要...
- 如何抓取有密码网页表格数据?简单易行!
-
众所周知,表格是一种常见的数据展示方式,而在网络世界中,许多网站也会采用表格的形式展示数据。但如果需要抓取这些表格中的数据,尤其是有帐号密码保护的网页,该如何实现呢?本文将为大家提供一种简单易行的方法...
- 不背锅运维:Grafana的自动登入(Go和Python分别实现)
-
1.实现目标想要达到的目标是:当在浏览器向http://192.168.11.254:3090/auto_login这个地址发起GET请求后能够自动登入Grafana...
- Python每日一库之requests python爬虫之requests库的下载
-
Pythonurllib...
- Javaweb知识 day16 Cookie&Session
-
今日内容1.会话技术1.Cookie2.Session2.JSP:入门学习一、会话技术1.1概念:会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止,一次会话中包含多次请...
- 全网最全的python网络爬虫常用技术
-
前言urllib模块urllib库是python中自带的模块,也是一个最基本的网络请求库,该模块提供了一个urlopen()方法,通过该方法指定URL发送网络请求来获取数据。正文urllib是一个收...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- JavaWeb开发入门需要学哪些?看完你就懂了
- Spring Boot 中如何实现通过Cookie来实现用户鉴权?
- Session和cookie笔记 session与cookie的关系
- 精读大型网站架构的技术细节:后端架构规整化Cookie和Session
- 一文彻底搞懂Cookie、Session、Token到底是什么
- Python常用的第三方包-Requests 5个常用python第三方库
- 干货 | REST-assured 获取日志到文件并结合 Allure 报告进行展示
- 前后端数据交互(四)——fetch 请求详解
- 【0基础学爬虫】爬虫基础之网络请求库的使用
- ASP.NET MVC开发日常一:SessionID更新
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)