Django表单forms碎碎念

Django有两个预制好的表单类forms.Form和forms.ModelForm。为什么要使用Django的forms?当然是因为我懒!

forms.Form


看下用forms.Form创建表单可以有多方便吧。
第一步:创建一个表单类,比如做个邮件采集

from django import forms

class TryAForm(forms.Form):
	email = forms.EmailField()

建议在views.py同级目录下创建一个form.py


第二步:在views.py的视图中调用这个表单类,看上去像这样

def try_it(request):
    if request.method == 'POST':
        try_a_form = TryAForm(request.POST)
        if try_a_form.is_valid():
            cd = try_a_form.cleaned_data #得到表单中的数据
            messages.success(request,'Hi~'+cd['username']) #通过列表读取字段值
    else:
        try_a_form = TryAForm() #如果不是POST,实例化一个空表单
    template = 'account/tryit.html'
    context = {
        'form':try_a_form,
    }
    return render(request,template,context)

第三部:编辑模版(account/tryit.html),增加以下内容

    <form action="." method="post">
        {{ form.as_p }}
        {% csrf_token %}
        <p><input type="submit" value="提交"></p>
    </form>

关于表单验证可以说是比较让人烦躁的工作之一,Django提供了数据验证功能,常用的Field参数了解下:

class TryAForm(forms.Form):
	char = forms.CharField(initial='hahaha',max_length=8,min_length=6,required=True,help_text='请输入6-8个字符')
	email = forms.EmailField(label='邮箱',empty_value='123@123.com',required=False)
	float = forms.FloatField(max_value=8,min_value=2,required=True)
	Int = forms.IntegerField(max_value=8,min_value=2,required=True)
	URL = forms.URLField(required=True)

比较常用的包括required(是否必填),empty_value(为空是自动补全),initial(初始值),disabled(不可编辑)

表单除了验证,还有样式的问题。我用的最多的是bootstrap,原因是我懒。个人感觉在同类样式库里,比较好上手,遇到问题,网上资料最多。

推荐使用django-widget-tweaks定制表单的bootstrap样式

pip install django-widget-tweaks
在项目的setting.py中添加插件

INSTALLED_APPS = [
	#...
    "widget_tweaks",
	#...
]

创建一个应用bootstrap样式的代码片段,比如tryit_snippet.html

{% load widget_tweaks %}
{% for field in form %}
    <div class="form-group">
    {{ field.errors }}
    <label for="{{ field.id_for_label }}" class="form-label" >
        {{ field.label }}
    </label>
    <!-- {{ field }} -->
    {% render_field field  class="form-control"  %}
    </div>
{% endfor %}

每个字段的div样式使用form-group,label样式用form-label,input字段使用form-control

编辑表单类,添加template_name=样式代码片段文件

class TryAForm(forms.Form):
	template_name = "account/tryit_snippet.html"
	char = forms.CharField(initial='hahaha',max_length=8,min_length=6,required=True,help_text='请输入6-8个字符')
	email = forms.EmailField(label='邮箱',empty_value='123@123.com',required=False)
	float = forms.FloatField(initial=6,disabled=True,required=True)
	Int = forms.IntegerField(max_value=8,min_value=2,required=True)
	URL = forms.URLField(required=True)

编辑模版文件,把form.as_p 更新为form

    <form action="." method="post">
        {{ form }}
        {% csrf_token %}
        <p><input type="submit" value="提交"></p>
    </form>

Django还提供了很多定制化部件,更多内容可以查看部件 | Django 文档 | Django (djangoproject.com)

ModelForm

我们在Django的模型中已经给每个字段做了定义,哪个是字符,哪个是数字等。使用forms.ModelForm可以快速根据模型的信息创建表单。

比如有一个用户信息的数据模型,直接让表单字段套用模型字段,像这样

from django import forms
from django.contrib.auth.models import User

class UserEditForm(forms.ModelForm):
	class Meta:
		model = User

不过这个就太简单粗暴了,项目中不太会这样用。不过一些非常简单的定制已经可以满足大部分的需求了,了解下:

class ProfileEditForm(forms.ModelForm):
	template_name = "account/form_snippet.html"
	class Meta:
		model = Profile
		fields = ('date_of_birth','photo')

		labels = {
			'date_of_birth':'出生日期',
			'photo':'我的头像',
		}

		widgets = {
			"date_of_birth":forms.TextInput(attrs={"class":"form-control"})
		}
		
	def __init__(self,*args,**kwargs):
		super().__init__(*args,**kwargs)
		# self.fields['date_of_birth'].widget.attrs.update({'class':'form-control'})
		self.fields['photo'].widget.attrs.update({'class':'form-control'})

大部分参数都是在Meta下配置的

model:需要绑定的model

fields:需要绑定表单的字段

labels:因为Model中的字段名都是英文,这里可以设置如何显示label

widgets:定制css样式

定义CSS样式的另一个方式是在初始化方法中定制self.fields[].widget.attrs.update()

HTML代码片段和在forms.Form用法是一样的

片段实例account/form_snippet.html

{% for field in form %}
<div>
    {{ field.errors }}
    <label for="{{ field.id_for_label }}" class="form-label" >
        {{ field.label }}
    </label>
    {{ field }}
</div>
<p> </p>
{% endfor %}

这里没有使用widget-tweaks,所以没有引入{% load widget_tweaks %}

因为input的样式通过widgets写到了表单类中。

  • 25
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django forms是一个用于处理表单的高级工具集,它提供了许多便捷的方法和函数,可以轻松地创建和处理表单Django forms的主要作用是将HTML表单Python代码联系起来,使得表单的输入数据可以被方便地处理和验证。 使用Django forms处理表单的基本步骤如下: 1. 创建一个表单类,该类继承自Django forms中的forms.Form类。 2. 在表单类中定义需要处理的表单字段,可以使用Django forms中提供的各种字段类型,如CharField、IntegerField等。 3. 在表单类中定义处理表单数据的方法,一般是通过Django forms中的cleaned_data属性获取表单数据,并进行相应的处理和验证。 4. 在视图函数中实例化表单类,并将接收到的请求数据传递给表单类实例,然后调用表单类中定义的处理表单数据的方法进行处理。 5. 如果表单数据验证通过,可以执行相应的逻辑,如果验证失败,可以重新渲染表单并输出错误提示信息。 以下是一个简单的Django forms表单处理示例代码: ```python # forms.py from django import forms class ContactForm(forms.Form): name = forms.CharField(max_length=100) email = forms.EmailField() message = forms.CharField(widget=forms.Textarea) def send_email(self): # 处理表单数据的方法 name = self.cleaned_data['name'] email = self.cleaned_data['email'] message = self.cleaned_data['message'] # 进行邮件发送等操作 ``` ```python # views.py from django.shortcuts import render from .forms import ContactForm def contact_view(request): if request.method == 'POST': form = ContactForm(request.POST) if form.is_valid(): form.send_email() return render(request, 'success.html') else: form = ContactForm() return render(request, 'contact.html', {'form': form}) ``` 在上面的示例代码中,我们定义了一个名为ContactForm的表单类,该类继承自Django forms中的forms.Form类,然后定义了三个需要处理的表单字段:name、email和message。在表单类中还定义了一个名为send_email的处理表单数据的方法,该方法通过cleaned_data属性获取表单数据,并进行相应的处理和验证。 在视图函数contact_view中,我们首先判断请求方法是否为POST,如果是POST请求,则实例化ContactForm表单类并将请求数据传递给它,然后调用is_valid方法进行表单数据验证。如果表单验证通过,我们就可以调用表单类中定义的send_email方法进行处理。如果表单验证失败,我们可以重新渲染表单并输出错误提示信息。 以上就是使用Django forms处理表单的基本步骤,通过Django forms,我们可以轻松地处理表单数据,并进行相应的验证和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值