使用基于类的视图进行表单处理


本文整理自网络,侵删。

形成基于类的意见处理

表单处理通常具有3条路径:

  • 初始GET(空白或预填充形式)
  • POST包含无效数据(通常重新显示带有错误的表单)
  • 使用有效数据进行POST(处理数据并通常重定向)

自己实现这一点通常会导致很多重复的样板代码(请参阅在视图中使用表单)。为了避免这种情况,Django提供了一组通用的基于类的视图以进行表单处理。

基本形式

给出联系表:

的forms.py 

from django import forms
?
class ContactForm(forms.Form):
  name = forms.CharField()
  message = forms.CharField(widget=forms.Textarea)
?
  def send_email(self):
      # send email using the self.cleaned_data dictionary
      pass

可以使用构造视图FormView:

的views.py 

from myapp.forms import ContactForm
from django.views.generic.edit import FormView
?
class ContactView(FormView):
  template_name = 'contact.html'
  form_class = ContactForm
  success_url = '/thanks/'
?
  def form_valid(self, form):
      # This method is called when valid form data has been POSTed.
      # It should return an HttpResponse.
      form.send_email()
      return super().form_valid(form)

笔记:

  • FormView是继承的, TemplateResponseMixin因此 template_name 可以在这里使用。
  • 的默认实现 form_valid()只是将重定向到success_url。

模型的形式

使用模型时,通用视图确实很出色。这些通用视图将自动创建一个ModelForm,只要它们能够确定要使用的模型类:

  • 如果model给定了属性,则将使用该模型类。
  • 如果get_object() 返回一个对象,则将使用该对象的类。
  • 如果queryset给出a,将使用该查询集的模型。

模型表单视图提供了一种 form_valid()自动保存模型的实现。如果有特殊要求,可以覆盖此设置。请参阅下面的示例。

您甚至不需要提供success_urlfor CreateView或 UpdateView- get_absolute_url()如果可用,它们将 在模型对象上使用。

如果要使用自定义ModelForm(例如添加额外的验证),请form_class在视图上进行设置 。

注意:指定自定义表单类时,即使form_class可能是,您仍必须指定模型ModelForm。

首先,我们需要添加get_absolute_url()到 Author类中:

models.py中

from django.db import models
from django.urls import reverse
?
class Author(models.Model):
  name = models.CharField(max_length=200)
?
  def get_absolute_url(self):
      return reverse('author-detail', kwargs={'pk': self.pk})

然后我们可以CreateView和朋友一起做实际的工作。注意这里我们是如何配置通用的基于类的视图的。我们不必自己编写任何逻辑:

的views.py 

from django.urls import reverse_lazy
from django.views.generic.edit import CreateView, DeleteView, UpdateView
from myapp.models import Author
?
class AuthorCreate(CreateView):
  model = Author
  fields = ['name']
?
class AuthorUpdate(UpdateView):
  model = Author
  fields = ['name']
?
class AuthorDelete(DeleteView):
  model = Author
  success_url = reverse_lazy('author-list')

注意:我们必须使用reverse_lazy()而不是 reverse(),因为导入文件时不会加载url。

该fields属性的工作方式与fields上内部Meta类的属性相同ModelForm。除非您以其他方式定义表单类,否则该属性是必需的,否则视图将引发ImproperlyConfigured异常。

如果同时指定fields 和form_class属性, ImproperlyConfigured则会引发异常。

最后,我们将这些新视图连接到URLconf中:

阅读剩余部分

相关阅读 >>

使用asgi进行部署

Django 简介

Django 使用表单模板

Django 的性能与优化

错误报告

部署清单

Django 创建第一个项目

内置基于类的通用视图

基于类的视图简介

部署静态文章

更多相关阅读请进入《Django》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...