¿Cómo podemos instalar rápidamente el Gestor de plantillas Smarty PHP?
Entre los problemas que pueden presentarse podemos destacar los siguientes:
* No tenemos control del servidor donde alojamos nuestro sitio, solo de un directorio.
* No tenemos conocimientos suficientes para configurar el servidor web.
* Hemos seguido el tutorial de la página oficial pero tuvimos problemas al entenderlo o simplemente no pudimos seguir los pasos.
* Estamos en Windows usando algún software que nos provee el entorno de desarrollo (Apache, PHP, MySQL, etc) pero no Smarty, y el tutorial de instalación no contempla este contexto.
* Etcétera.
¿Qué es Smarty?
Smarty es un conjunto reducido de clases que ofrecen la funcionalidad de "templates html" para desarrollos basados en PHP, donde terminamos usando una instancia (POO) para manipular la información y el comportamiento del motor de templates.
Solución que recomiendo
Bajar el paquete Smarty y descomprimirlo en el directorio donde se encuentra nuestro sitio web.
Ejemplo
Si el directorio en el servidor web es "/www/" y el directorio de nuestro sitio es "miportal", la ruta completa sería "/www/miportal".
Si nos bajamos el paquete de Smarty del sitio oficial, este vendrá comprimido y con la siguiente nomenclatura: "Smarty 2.6.26". Está nomenclatura indica la versión del gestor.
En este punto deberiamos cambiar el nombre del directorio de Smarty a "smarty" sin números, ni espacios, ni caracteres extraños.
Directorios necesarios
* templates: este directorio contendrá los templates para nuestras páginas web, es decir, los archivos .tpl.html que contienen código html + código Smarty con la posibilidad de ser invocado desde un PHP.
* templates_c: es el directorio temporal donde el sistema lee los templates del directorio anterior y genera un nuevo html de forma dinámica con el código resuelto, es decir, código html y la sustitución de todas las variables cargadas y las sentencias propias resultas por el Smarty. Este resultado es la "página final", lo que recibirá el usuario cuando navegue nuestro sitio web.
Prueba
Para probar la plantilla creada, podemos usar el siguiente ejemplo.
<?
require_once("Smarty/libs/Smarty.class.php");
$miSmarty = new Smarty();
$miSmarty->template_dir = 'templates';
$miSmarty->config_dir = 'config';
$miSmarty->cache_dir = 'cache';
$miSmarty->compile_dir = 'templates_c';
$miSmarty->assign("titulo", "Hola mundo con Smarty");
$miSmarty->display("formulario.tpl.html");
?>
Incluimos la clase base "Smarty.class.php" y luego creamos la primer instancia de nuestro template, modificamos los atributos de la clase para definir donde estarán los directorios necesarios para su trabajo y creamos una variable del template (assign) y le cargamos el título del formulario ("Hola mundo con Smarty").
Finalmente, invocamos el template con el método "display".
Nuestro primer template
Podemos usar la nomenclatura que más nos guste; en este caso seguimos los ejemplos de la documentación oficial: nombredearchivo.tpl.html, donde "tpl" es la abreviación de template y obviamente "html" porque es un archivo con ese formato. Esto último es útil para poder editar el archivo en nuestro editor HTML de preferencia.
Deberemos tener creado el archivo "holamundo.tpl.html" en el directorio "template" con el siguiente contenido:
{$titulo}
Donde el "{$titulo}" será sustituido con el contenido especificado en archivo PHP.
En Resumen
Logramos instalar Smarty sin depender de la configuración del servidor, sin necesitar tener acceso como administradores. Logramos modificar su comportamiento, creamos la primer instancia del objeto y logramos ejecutar el primer template.
Ahora tenemos el camino abierto para aprender a usarlo.
Proximamente abordaremos los temas iniciales de como empezar a usar el gestor de plantillas Smarty.
Un saludo.