php

Funciones y métodos en Twig

El motor de plantillas de Twig permite crear funciones que podemos invocar directamente en la vista.

Aunque hay que separar la vista de la lógica, en ocasiones es necesario crear funciones o métodos en Twig para acceder a cosas de la lógica.

En este post te mostraré cómo crear funciones en Twig.

Declarar función en Twig

Supongo que ya tienes un entorno de Twig. Por ejemplo:

<?php
use Twig\TwigFunction;
use Twig\Loader\FilesystemLoader;
$loader = new FilesystemLoader(DIRECTORIO_RAIZ . "/vistas");
$twig = new Environment($loader, [
    "cache" => $rutaCacheTwig,
]);

Para crear una función puedes usar TwigFunction (Twig\TwigFunction) así:

<?php
# en la parte superior va la siguiente línea...
use Twig\TwigFunction;
# Después puedes definir la función ;)
$funcion = new TwigFunction("nombre_funcion", function(){
    return "Todo bien";
});

El primer argumento es el nombre de la función y el segundo es la función en sí. En este caso la función (dentro de Twig) se llama nombre_funcion.

Agregar función a Twig

Hemos creado la función pero no la hemos agregado. Para agregarla, una vez que ya la hemos definido, invocamos a addFunction en el entorno:

<?php
$funcion = new TwigFunction("nombre_funcion", function(){
    return "Todo bien";
});
# La agregamos
$twig->addFunction($funcion);

Usar función en la vista

Después, dentro de la vista, usamos la función. Podemos encerrar su resultado en una variable o simplemente invocar a la función. En mi caso:

<h1 class="text-center">Agregar usuario {{ nombre_funcion() }}</h1>

Y al renderizar:

Argumentos en funciones de Twig

Como cualquier otra función, las funciones o métodos de Twig pueden recibir argumentos:

<?php
$funcion = new TwigFunction("saludo", function($nombre){
    return "Hola, $nombre";
});
$twig->addFunction($funcion);

Definimos el nombre de la función, y el callable. Dentro del callable indicamos que vamos a recibir un argumento llamado $nombre, después regresamos un saludo.

En este caso solo estoy regresando un valor; las funciones, como toda función de PHP, pueden o no devolver algo, así como realizar otras acciones.

El punto es que para invocar esa función se hace lo siguiente:

<h1 class="text-center">Agregar usuario {{ saludo('Luis') }}</h1>

Con el resultado que se ve en la imagen:

Funciones en Twig con funciones existentes

Como el segundo argumento para una TwigFunction es un callable, podemos indicarle el nombre de una función que ya existe. De este modo podemos exponer funciones de PHP en la vista de Twig.

Por ejemplo, voy a exponer la función date que sirve, entre otras cosas, para formatear la fecha actual.

Comienzo agregando la función. No te confundas, el nombre de la función dentro de Twig es date, y le estoy pasando el nombre de otra función callable que ya existe en PHP, llamada date (podría ser otra función como in_array, function_exists, etcétera)

<?php
$funcion = new TwigFunction("date", "date");
$twig->addFunction($funcion);

Después se utiliza así:

<h1 class="text-center">Agregar usuario {{ date('Y-m-d') }}</h1>

Con el siguiente resultado:

Obviamente si date no recibiera argumentos no tendríamos que indicarlos. Como lo dije, esto es usar una función normal de PHP en Twig, ya sea que regrese o no regrese algo, o haga o no haga algo.

Si quieres el ejemplo completo o un lugar en donde se use, mira mi plantilla para proyectos de PHP.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Entradas recientes

Tramitar acta de nacimiento en línea de manera instantánea

En este post te quiero compartir mi experiencia tramitando un acta de nacimiento de México…

25 min hace

Creador de credenciales web – Aplicación gratuita

Hoy te voy a presentar un creador de credenciales que acabo de programar y que…

2 semanas hace

Desplegar PWA creada con Vue 3, Vite y SQLite3 en Apache

Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…

2 semanas hace

Arquitectura para wasm con Go, Vue 3, Pinia y Vite

En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…

2 semanas hace

Vue 3 y Vite: crear PWA (Progressive Web App)

En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…

2 semanas hace

Errores de Comlink y algunas soluciones

Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…

2 semanas hace

Esta web usa cookies.