Como crear Context Processors en Django

El contexto es un “conjunto de variables” que envías a tus templates a través de las vistas. Estas variables solo pueden ser accedidas por un template específico. Pero, que sucede si nuestro proyecto requiere variables que estén disponibles en todos los templates. No conviene estar agregando el mismo conjunto de elementos en cada contexto de cada vista. Lo que necesitamos es crear un contexto global, es decir, un conjunto de variables globales que todas las plantillas podrán usar.

Entonces, ¿cómo se creo un contexto global? Aquí los context processors entran al rescate.

¿Qué son los Context Processors?

Un procesador de contexto es sencillamente una función que recibe un argumento request y retorna un diccionario de elementos (contexto).

def mi_context_processor(request):
    return {
        "foo": "bar",
    }Code language: Python (python)

La variable user es un ejemplo de variable global definida en un context processor. Esta nos retorna el usuario que se encuentra logueado actualmente. Puedes acceder a esta variable desde cualquier template de tu proyecto. ¡Pruébalo!

<h1>{{ user.username }}</h1>Code language: HTML, XML (xml)

El context processor auth contiene un conjunto de variables, entre ellas esta la variable user que usamos anteriormente. Puedes encontrarla en tu settings.py de esta forma:

django.contrib.auth.context_processors.authCode language: Bash (bash)

Crea tu propio Context Processor

Crearemos una variable global que nos retorne el año actual.

Primero crea un archivo context_processors.py y luego definamos nuestro context processor get_current_year:

# context_processors.py

import datetime

def get_current_year(request):
    current_year = datetime.datetime.now().year

    return {
        "current_year": current_year
    }
Code language: Python (python)

Finalmente, debes agregar tu nuevo context processor en la configuración TEMPLATES para que puedas fusionarlo con el contexto global. De esta forma, podrás acceder a los elementos en todas las plantillas.

# settings.py

TEMPLATES = [
    {
        # ...
        "OPTIONS":
            {
                "context_processors":
                    [
                        "django.template.context_processors.debug",
                        "django.template.context_processors.request",
                        "django.contrib.auth.context_processors.auth",
                        "django.contrib.messages.context_processors.messages",
                        "myapp.context_processors.get_current_year",
                    ],
            },
    },
]
Code language: PHP (php)

Y listo, puedes usar la nueva variable current_year desde cualquier plantilla de tu proyecto.

<h1>{{ current_year }}</h1>Code language: HTML, XML (xml)

Gracias por leer el artículo, para cualquier duda deja un comentario.

Compartir:
Suscríbete para recibir artículos de desarrollo web

En este boletín envío correos relacionados al área del diseño y desarrollo web. Escribo sobre WordPress y AstroJS, a veces un poco de UX/UI.

3 Responses

  1. hola, muy aclaratorio. Necesito en una vista usar esta variable para un query(insert). No logro verla, he tratado con current_year o request.current_year sin exito, me indica que no existe.

Agregue un comentario

Su dirección de correo no se hará público. Los campos requeridos están marcados *

12 Webs famosas que han sido creadas con Django

Cómo configurar variables de entorno en Django

Cómo usar Django Signals