Maison >développement back-end >Tutoriel Python >Notes d'étude de Django - Vue basée sur les classes
Avant-propos
Tout le monde sait qu'apprendre Django est en fait très simple et que vous pouvez commencer avec presque aucun effort. Il n'y a presque rien de difficile à comprendre concernant la configuration d'une URL, son assignation à une fonction pour la traiter et le renvoi d'une réponse.
Plus j’écris, plus je réalise certains problèmes. Par exemple, une vue est relativement complexe et appelle de nombreuses autres fonctions. Que dois-je faire si je souhaite encapsuler ces fonctions ? Bien sûr, vous pouvez utiliser le commentaire #------view------ pour isoler la fonction. Cette méthode est tout simplement trompeuse. Elle n'est même pas encapsulée.
Python est un langage de programmation orienté objet. Si vous utilisez uniquement des fonctions pour développer, de nombreux avantages orientés objet seront manqués (héritage, encapsulation, polymorphisme). Django a donc ajouté plus tard Class-Based-View. Cela nous permet d'écrire View en utilisant des classes. Les avantages de ceci sont principalement les deux suivants :
Améliore la réutilisabilité du code et vous pouvez utiliser une technologie orientée objet, telle que Mixin (héritage multiple)
Vous pouvez utiliser différentes fonctions pour gérer différentes méthodes HTTP au lieu d'en utiliser plusieurs jugements if pour améliorer la lisibilité du code
utiliser la classe- vues basées
Si nous voulons écrire une vue qui gère la méthode GET, ce serait comme suit lorsqu'elle est écrite à l'aide d'une fonction.
from django.http import HttpResponse def my_view(request): if request.method == 'GET': # <view logic> return HttpResponse('result')
S'il était écrit en vue basée sur les classes, cela ressemblerait à ceci.
from django.http import HttpResponse from django.views import View class MyView(View): def get(self, request): # <view logic> return HttpResponse('result')
L'URL de Django attribue une requête à une fonction appelable, pas à une classe. Pour résoudre ce problème, la vue basée sur les classes fournit une méthode statique as_view()
(c'est-à-dire que l'appel de cette méthode créera une instance de la classe, puis appellera la méthode dispatch()
via l'instance). > sera appelée en fonction de la requête. Différentes méthodes appellent la méthode correspondante pour gérer la requête (telle que dispatch()
, get()
, etc.). À ce stade, ces méthodes sont presque identiques aux vues basées sur les fonctions. Elles doivent recevoir des requêtes et obtenir une réponse. Si la méthode n'est pas définie, une exception HttpResponseNotAllowed sera levée. post()
# urls.py from django.conf.urls import url from myapp.views import MyView urlpatterns = [ url(r'^about/$', MyView.as_view()), ]Les attributs de la classe peuvent être définis de deux manières, la première est commune Les méthodes Python peuvent être remplacées par des sous-classes.
from django.http import HttpResponse from django.views import View class GreetingView(View): greeting = "Good Day" def get(self, request): return HttpResponse(self.greeting) # You can override that in a subclass class MorningGreetingView(GreetingView): greeting = "Morning to ya"Deuxième méthode, vous pouvez également spécifier les attributs de la classe dans l'url : Définir les attributs de la classe dans l'url Python
urlpatterns = [ url(r'^about/$', GreetingView.as_view(greeting="G'day")), ]
Utilisation de Mixin
Utiliser des décorateurs
from django.contrib.auth.decorators import login_required from django.utils.decorators import method_decorator from django.views.generic import TemplateView class ProtectedView(TemplateView): template_name = 'secret.html' @method_decorator(login_required) def dispatch(self, *args, **kwargs): return super(ProtectedView, self).dispatch(*args, **kwargs)peut également être écrit sur la classe et passer au nom de la méthode.
@method_decorator(login_required, name='dispatch') class ProtectedView(TemplateView): template_name = 'secret.html'S'il y a plusieurs décorateurs décorant une méthode, ils peuvent être écrits sous forme de liste. Par exemple, les deux manières d’écrire suivantes sont équivalentes.
decorators = [never_cache, login_required] @method_decorator(decorators, name='dispatch') class ProtectedView(TemplateView): template_name = 'secret.html' @method_decorator(never_cache, name='dispatch') @method_decorator(login_required, name='dispatch') class ProtectedView(TemplateView): template_name = 'secret.html'