Classes mixins pour objet unique¶
SingleObjectMixin¶
-
class
django.views.generic.detail.SingleObjectMixin¶ Fournit un mécanisme pour rechercher un objet associé à la requête HTTP en cours.
Méthodes et attributs
-
model¶ Le modèle pour lequel cette vue va afficher des données. Indiquer
model = Foorevient au même que de définirqueryset = Foo.objects.all(), oùobjectscorrespond au gestionnaire par défaut deFoo.
-
queryset¶ Un objet
QuerySetreprésentant les objets. Lorsqu’elle est renseignée, la valeur dequerysetécrase la valeur fournie pourmodel.Avertissement
querysetest un attribut de classe avec une valeur modifiable, il faut donc être très prudent lorsqu’on l’utilise directement. Avant de l’utiliser, appelez sa méthodeall()ou obtenez-la avecget_queryset()qui se charge du clonage en arrière-plan.
-
slug_field¶ Le nom du champ de modèle qui contient le slug. Par défaut,
slug_fieldest'slug'.
-
slug_url_kwarg¶ Le nom du paramètre nommé dans l’URL contenant le slug. Par défaut,
slug_url_kwargest'slug'.
-
pk_url_kwarg¶ Le nom du paramètre nommé dans l’URL contenant la clé primaire. Par défaut,
pk_url_kwargest'pk'.
-
context_object_name¶ Désigne le nom de la variable à utiliser dans le contexte.
-
query_pk_and_slug¶ Si
True, indique àget_object()de rechercher un objet à la fois avec la clé primaire et le « slug ». VautFalsepar défaut.Cet attribut peut contribuer à prévenir les attaques de référence directe d’objet non sécurisé. Lorsque des applications permettent d’accéder à des objets individuels par une clé primaire séquentielle, un attaquant pourrait deviner toutes les URL par force brute, obtenant par là-même une liste de tous les objets de l’application. Si ceux qui peuvent accéder aux objets individuels ne devraient pas pouvoir obtenir toute la liste, la définition de
query_pk_and_slugàTrueaide à empêcher la découverte des URL du fait que chaque URL nécessite deux paramètres corrects et non séquentiels. On pourrait obtenir un résultat semblable en exigeant un slug unique, mais ce système permet d’avoir des slugs non uniques.
-
get_object(queryset=None)¶ Renvoie l’objet unique que cette vue va afficher. Si
querysetest indiqué, ce jeu de requête est utilisé comme source des objets ; sinon,get_queryset()est appelée.get_object()recherche un paramètrepk_url_kwargdans les paramètres de la vue ; si ce paramètre est trouvé, cette méthode effectue une sélection basée sur la clé primaire avec cette valeur. Dans le cas contraire, elle consulte le paramètreslug_url_kwarget effectue une sélection basée sur le slug avec la valeurslug_field.Lorsque
query_pk_and_slugvautTrue,get_object()rechercher son objet à la fois avec la clé primaire et le « slug ».
-
get_queryset()¶ Renvoie le jeu de requête qui sera utilisé pour récupérer l’objet que cette vue va afficher. Par défaut,
get_queryset()renvoie la valeur de l’attributquerysets’il est défini, sinon elle construit un objetQuerySeten appelant la méthodeall()sur le gestionnaire par défaut de l’attributmodel.
-
get_context_object_name(obj)¶ Renvoie le nom de la variable de contexte utilisée pour contenir les données que cette vue manipule. Si
context_object_namen’est pas défini, le nom du contexte correspondra au nom de modèle des objets contenus dans le jeu de requête. Par exemple, pour le modèleArticle, la variable de contexte sera nommée'article'.
-
get_context_data(**kwargs)¶ Renvoie les données du contexte pour afficher l’objet.
L’implémentation de base de cette méthode exige que l’attribut
self.objectsoit défini par la vue (même avecNone). Assurez-vous de le définir si vous utilisez cette classe mixin sans l’une des vues intégrées qui le fait.Renvoie un dictionnaire contenant :
object: l’object affiché par cette vue (self.object).context_object_name:self.objectsera aussi stocké sous le nom renvoyé parget_context_object_name(), qui équivaut par défaut au nom de modèle en minuscules.
Les variables de contexte écrasent les valeurs provenant des processeurs de contexte des gabarits
Toute variable de
get_context_data()a la priorité sur les variable de contexte provenant des processeurs de contexte. Par exemple, si une vue définit l’attributmodelàUser, le nom d’objet de contexte par défautuserécrase la variableuserdéfinie par le processeur de contextedjango.contrib.auth.context_processors.auth(). Utilisezget_context_object_name()pour éviter cette collision.
-
get_slug_field()¶ Renvoie le nom d’un champ de type slug à utiliser lors de la sélection par slug. Par défaut, cette méthode renvoie simplement la valeur de
slug_field.
-
SingleObjectTemplateResponseMixin¶
-
class
django.views.generic.detail.SingleObjectTemplateResponseMixin¶ Une classe mixin produisant une réponse basée sur un gabarit pour les vues opérant sur une seule instance d’objet. Exige que la vue dans laquelle elle est intégrée fournisse
self.object, l’instance d’objet sur laquelle la vue opère.self.objectest généralement une instance d’un modèle Django, mais ce n’est pas une règle absolue. Elle peut valoirNonesi la vue est en cours de construction d’une nouvelle instance.Étend
Méthodes et attributs
-
template_name_field¶ Le champ de l’instance d’objet actuelle pouvant être utilisé pour déterminer le nom d’un gabarit potentiel. Si
template_name_fieldlui-même ou la valeur detemplate_name_fieldpour l’instance d’objet actuelle vautNone, l’objet ne sera pas utilisé pour trouver un nom de gabarit potentiel.
-
template_name_suffix¶ Le suffixe à ajouter au nom de gabarit auto-généré. Le suffixe par défaut est
_detail.
-
get_template_names()¶ Renvoie une liste de noms de gabarits potentiels. Cette liste contient :
- la valeur de
template_namede la vue (s’il est défini) - le contenu du champ
template_name_fieldde l’instance d’objet sur laquelle la vue opère (si disponible) <nom_app>/<nom_modèle><suffixe_gabarit>.html
- la valeur de
-