Django 基本视图(view、TemplateView、RedirectView)

基于类的通用视图 - 展平索引

view、TemplateView、RedirectView这三个类实现了创建Django类视图的大部分功能。可以将他们视为父视图,他们可以单独使用,也可以从中继承。
可能它们无法提供项目所需的所有功能,在这种情况下,可以使用Mixins和Generic基于类的视图。

许多Django的内置基于类的视图都继承自其他基于类的视图或各种mixin。因为这个继承链非常重要,所以祖先类记录在祖先(MRO)的标题下。MRO
Method Resolution Order的首字母缩写。

一、View 

django.views.generic.base.View

基于主类的基本视图。所有其他基于类的视图都从此基类继承。它不是严格意义上的通用视图,因此也可以从中导入django.views。

方法流程图

  •     dispatch()
  •     http_method_not_allowed()
  •     options()

属性:
    http_method_names
    此视图将接受的HTTP方法名称列表。
    默认:
    ['get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace']

方法:
    classmethodas_view(** initkwargs)
    返回一个可调用的视图,该视图接收请求并返回响应:

    response = MyView.as_view()(request)
    返回的视图具有view_classview_initkwargs 属性。

    示例views.py:

from django.http import HttpResponse
from django.views import View

class MyView(View):

    def get(self, request, *args, **kwargs):
        return HttpResponse('Hello, World!')

示例urls.py:

from django.urls import path

from myapp.views import MyView

urlpatterns = [
    path('mine/', MyView.as_view(), name='my-view'),
]

在请求/响应周期中调用HttpRequest视图时,request 会将其分配给视图的属性。
从URL模式捕获的任何位置和/或关键字参数分别分配给 args和kwargs属性。然后dispatch() 被叫。

dispatch(请求,* args,** kwargs)
view视图的一部分 - 接受request 参数和参数的方法,并返回HTTP响应。

默认实现将检查HTTP方法并尝试委托给与HTTP方法匹配的方法; a GET将被委派给get()a,POSTto post(),等等。

默认情况下,HEAD将委派一个请求get()。如果您需要以HEAD不同的方式处理请求GET,则可以覆盖该head()方法。有关示例,请参阅 支持其他HTTP方法。

http_method_not_allowed(请求,* args,** kwargs)
如果使用不支持的HTTP方法调用视图,则会调用此方法。

默认实现返回HttpResponseNotAllowed纯文本中允许的方法列表。

options(请求,* args,** kwargs)
处理响应OPTIONS HTTP动词请求的句柄。返回Allow包含视图允许的HTTP方法名称列表的标头的响应。

二、TemplateView 

django.views.generic.base.TemplateView

呈现给定模板,其中包含在URL中捕获的参数的上下文。

此视图继承的视图类

    django.views.generic.base.TemplateResponseMixin
    django.views.generic.base.ContextMixin
    django.views.generic.base.View

方法流程图

dispatch()
http_method_not_allowed()
get_context_data()

实例:views.py

from django.views.generic.base import TemplateView

from articles.models import Article

class HomePageView(TemplateView):

    template_name = "home.html"

    def get_context_data(self, **kwargs):
        context = super().get_context_data(**kwargs)
        context['latest_articles'] = Article.objects.all()[:5]
        return context

示例urls.py:

from django.urls import path

from myapp.views import HomePageView

urlpatterns = [
    path('', HomePageView.as_view(), name='home'),
]

三、RedirectView

 django.views.generic.base.RedirectView

重定向到给定的URL。

给定的URL可能包含字典样式的字符串格式,将根据URL中捕获的参数进行插值。因为关键字插值总是完成(即使没有传入参数),

如果给定的URL是None,Django将返回一个HttpResponseGone (410)。

此视图继承的视图类

django.views.generic.base.View

方法流程图

    dispatch()
    http_method_not_allowed()
    get_redirect_url()
    
示例views.py:

from django.shortcuts import get_object_or_404
from django.views.generic.base import RedirectView

from articles.models import Article

class ArticleCounterRedirectView(RedirectView):

    permanent = False
    query_string = True
    pattern_name = 'article-detail'

    def get_redirect_url(self, *args, **kwargs):
        article = get_object_or_404(Article, pk=kwargs['pk'])
        article.update_counter()
        return super().get_redirect_url(*args, **kwargs)
        


示例urls.py:

from django.urls import path
from django.views.generic.base import RedirectView

from article.views import ArticleCounterRedirectView, ArticleDetail

urlpatterns = [
    path('counter//', ArticleCounterRedirectView.as_view(), name='article-counter'),
    path('details//', ArticleDetail.as_view(), name='article-detail'),
    path('go-to-django/', RedirectView.as_view(url='https://djangoproject.com'), name='go-to-django'),
]

属性

url
要重定向到的字符串作为字符串。如果是None引发410(Gone)HTTP错误。

pattern_name
要重定向到的URL模式的名称。使用与此视图传入的相同的args和kwargs将完成反转。

permanent
重定向是否应该是永久性的。这里唯一的区别是返回的HTTP状态代码。
如果True,那么重定向将使用状态代码301.如果False,则重定向将使用状态代码302.默认情况下,permanent是False。

query_string
是否将GET查询字符串传递给新位置。如果 True,则查询字符串将附加到URL。如果False,则丢弃查询字符串。默认情况下query_string是 False。

方法

get_redirect_url(* args,** kwargs)
构造重定向的目标URL。

默认实现url用作起始字符串,并%使用URL中捕获的命名组在该字符串中执行命名参数的扩展。

如果url未设置,则get_redirect_url()尝试反转 pattern_name使用URL中捕获的内容(使用已命名和未命名的组)。

如果请求query_string,它还会将查询字符串附加到生成的URL。子类可以实现他们希望的任何行为,只要该方法返回可重定向的URL字符串即可。

你可能感兴趣的:(Django,Python,Django2)