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()), ]
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"
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)
@method_decorator(login_required, name='dispatch') class ProtectedView(TemplateView): template_name = 'secret.html'
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'