📜  Django-通用视图

📅  最后修改于: 2020-10-25 10:02:17             🧑  作者: Mango


在某些情况下,如我们先前所见,编写视图确实很繁琐。假设您需要一个静态页面或一个列表页面。 Django提供了一种简单的方法来设置这些简单的视图,称为通用视图。

与经典视图不同,通用视图是类而不是函数。 Django在django.views.generic中为通用视图提供了一组类,每个通用视图都是这些类之一或从其中一个继承的类。

有10个以上;泛型类-

>>> import django.views.generic
>>> dir(django.views.generic)

['ArchiveIndexView', 'CreateView', 'DateDetailView', 'DayArchiveView', 
   'DeleteView', 'DetailView', 'FormView', 'GenericViewError', 'ListView', 
   'MonthArchiveView', 'RedirectView', 'TemplateView', 'TodayArchiveView', 
   'UpdateView', 'View', 'WeekArchiveView', 'YearArchiveView', '__builtins__', 
   '__doc__', '__file__', '__name__', '__package__', '__path__', 'base', 'dates', 
   'detail', 'edit', 'list']

您可以将其用于常规视图。让我们看一些示例以了解其工作原理。

静态页面

让我们从“ static.html”模板发布静态页面。

我们的static.html-

This is a static page!!! 
   

如果我们按照以前学习的方式进行操作,则必须将myapp / views.py更改为-

from django.shortcuts import render

def static(request):
   return render(request, 'static.html', {})

myapp / urls.py是-

from django.conf.urls import patterns, url

urlpatterns = patterns("myapp.views", url(r'^static/', 'static', name = 'static'),)

最好的方法是使用通用视图。为此,我们的myapp / views.py将变为-

from django.views.generic import TemplateView

class StaticView(TemplateView):
   template_name = "static.html"

而我们的myapp / urls.py我们将-

from myapp.views import StaticView
from django.conf.urls import patterns

urlpatterns = patterns("myapp.views", (r'^static/$', StaticView.as_view()),)

访问/ myapp / static时,您会得到-

静态页面

对于相同的结果,我们还可以执行以下操作-

  • views.py没有变化
  • 将url.py文件更改为-
from django.views.generic import TemplateView
from django.conf.urls import patterns, url

urlpatterns = patterns("myapp.views",
   url(r'^static/',TemplateView.as_view(template_name = 'static.html')),)

如您所见,您只需要在第二种方法中更改url.py文件。

列出和显示数据库中的数据

我们将列出Dreamreal模型中的所有条目。通过使用ListView通用视图类,可以轻松做到这一点。编辑url.py文件并将其更新为-

from django.views.generic import ListView
from django.conf.urls import patterns, url

urlpatterns = patterns(
   "myapp.views", url(r'^dreamreals/', ListView.as_view(model = Dreamreal, 
      template_name = "dreamreal_list.html")),
)

此时要注意的重要一点是,通用视图传递给模板的变量是object_list。如果要自己命名,则需要在as_view方法中添加一个context_object_name参数。然后url.py将变成-

from django.views.generic import ListView
from django.conf.urls import patterns, url

urlpatterns = patterns("myapp.views",
   url(r'^dreamreals/', ListView.as_view(
      template_name = "dreamreal_list.html")),
      model = Dreamreal, context_object_name = ”dreamreals_objects” ,)

关联的模板将是-

{% extends "main_template.html" %}
{% block content %}
Dreamreals:

{% for dr in object_list %} {{dr.name}}

{% endfor %} {% endblock %}

访问/ myapp / dreamreals /将产生以下页面-

列出和显示数据库中的数据