28 May, 2008

Componentes y helpers en cakephp

Tanto los componentes como los helpers están diseñados para extender las funcionalidades que el propio núcleo cake nos ofrece. La diferencia? bien sencilla. Mientras los componentes añaden lógica de negocio a nuestro proyecto, los helpers añaden lógica de presentación.

Componentes:
Existen multitud de componentes que podemos descargar y utilizar: Sending Email With PHPMailer, Integrate CakePHP with Kcaptcha, Google Geocoder, LastRSS CakePHP Component, Pagination Component, etc. Y otros que ya vienen incluidos con el núcleo cake: AuthComponent (Gestión y autenticación de usuarios), RequestHandler (Obtener información de las peticiones http), CookieComponent (Gestor de cookies), AclComponent (Access Control List), EmailComponent (Envio de mails), SecurityComponent (Incrementar la seguridad de tu aplicación), SessionComponent (Gestor de session). Y podemos crear nuestros propios componentes para cumplir diferentes requisitos:

Crear un nuevo componente para cakephp es muy sencillo. Basta con crear un fichero en app/controllers/components/fichero.php con una clase nombrada FicheroComponent que tendrá una variable $controller y un método:

  1. function startup( &$controller ) {
  2.      $this->controller = &$controller;
  3. }

Luego para hacer uso de un componente en uno de nuestros controladores simplemente lo añadimos al array

  1. var $components = array('NuestroComponente','OtroComponente');

y ya lo tendremos disponible como

  1. $this->NuestroComponente

Aqui tenemos un buen ejemplo de uso del json component.

Helpers:
Respecto a los helpers también los tenemos incluidos en el núcleo cake: html (ayuda a contruir tags html), form (ayuda a contruir formularios), number (ayuda a formatear numeros), timer (ayuda a formatear fechas), xml (simplifica la construcción de documentos xml), ajax (uso de ajax mediante prototype). Su uso es tan sencillo como:

  1. <div id="header">
  2.    <h1><?php echo $html->link(__('Portada', true), $html->base.'/portada'); ?></h1>
  3. </div>
  4. <!--Hacemos uso del helper $html tanto para crear un link como para obtener la dirección base de nuestra web.-->

Al igual que los componentes también podemos desarrollar nuestros propios helpers, aqui tenemos un buen ejemplo donde se crea un helper para autocompletar un input text mediante ajax .

1 Comment »

RSS feed for comments on this post. TrackBack URL

Leave a comment

Powered by WordPress
Bajo licencia Creative Commons
Contacto sanroman.javier at gmail.com