Edición de «Como Usar los Modelos en KumbiaPHP»
De KumbiaPHP Framework Wiki
Advertencia: no has iniciado sesión. Tu dirección IP se hará pública si haces cualquier edición. Si inicias sesión o creas una cuenta, tus ediciones se atribuirán a tu nombre de usuario, además de otros beneficios.
Puedes deshacer la edición. Antes de deshacer la edición, comprueba la siguiente comparación para verificar que realmente es lo que quieres hacer, y entonces guarda los cambios para así efectuar la reversión.
Revisión actual | Tu texto | ||
Línea 1: | Línea 1: | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
== Introducción == | == Introducción == | ||
− | Los Modelos representan la lógica de la aplicación | + | Los Modelos representan la lógica de la aplicación y son parte fundamental para el momento que se desarrolla una aplicación, un buen uso de estos nos permiten un gran poder al momento que se necesita escalar, mantener y rehusar código en una aplicación. |
− | Por lo general un mal uso de los modelos es solo dejar el archivo con la declaración de la clase y toda la lógica se genera en el controlador. Esta práctica trae como consecuencia que en primer lugar el controlador sea | + | Por lo general un mal uso de los modelos es solo dejar el archivo con la declaración de la clase y toda la lógica se genera en el controlador. Esta práctica trae como consecuencia que en primer lugar el controlador sea entendible por alguien que intente agregar y/o modificar algo en esa funcionalidad, en segundo lugar lo poco que puedes rehusar el código en otros controladores y lo hace es repetirse el código que hace lo mismo en otro controlador. |
Partiendo de este principio los controladores '''NO''' deberían contener ningún tipo de lógica solo se encargan de atender las peticiones del usuarios y solicitar dicha información a los modelos con esto garantizamos un buen uso del [http://es.wikipedia.org/wiki/Modelo_Vista_Controlador MVC]. | Partiendo de este principio los controladores '''NO''' deberían contener ningún tipo de lógica solo se encargan de atender las peticiones del usuarios y solicitar dicha información a los modelos con esto garantizamos un buen uso del [http://es.wikipedia.org/wiki/Modelo_Vista_Controlador MVC]. | ||
==El Modelo extiende el ActiveRecord== | ==El Modelo extiende el ActiveRecord== | ||
− | + | KumbiaPHP usa POO (Programación orientada a objetos), asi que ActiveRecord es una clase que ya lleva métodos listos para usar. Que facilitan al usuario el manejo de las tablas de las bases de datos, metodos como: find, find_all, save, update,... | |
− | El Modelo extiende la clase | + | El Modelo extiende la clase ActiveRecord para que el usuario pueda añadir sus métodos, y asi encapsular la logica. |
== Un Buen Modelo == | == Un Buen Modelo == | ||
Línea 42: | Línea 36: | ||
public function buscar($busqueda){ | public function buscar($busqueda){ | ||
$busqueda = filter_var($busqueda, FILTER_SANITIZE_STRING); | $busqueda = filter_var($busqueda, FILTER_SANITIZE_STRING); | ||
− | return $this->find_all_by_sql("SELECT * FROM | + | return $this->find_all_by_sql("SELECT * FROM copa.articulos a WHERE MATCH (titulo,texto) |
AGAINST('\"$busqueda\"' IN BOOLEAN MODE) ORDER BY creat_at DESC"); | AGAINST('\"$busqueda\"' IN BOOLEAN MODE) ORDER BY creat_at DESC"); | ||
Línea 49: | Línea 43: | ||
</source> | </source> | ||
− | Normalmente este código muchos usuarios lo colocan en el controller quedando el mismo '''ilegible''', | + | Normalmente este código muchos usuarios lo colocan en el controller quedando el mismo '''ilegible''', colocandolo como se muestra arriba queda muy limpia la implementación de los mismo en nuestros modelos en los controller. |
== Implementando mis modelos en los controladores == | == Implementando mis modelos en los controladores == | ||
Línea 56: | Línea 50: | ||
<source lang=php> | <source lang=php> | ||
<?php | <?php | ||
− | class MiController extends | + | class MiController extends ApplicationController |
{ | { | ||
public function index ($id = 1) | public function index ($id = 1) | ||
{ | { | ||
− | $this->noticias = | + | $this->noticias = $this->Articulos->ver($id); |
} | } | ||
public function ver ($slug) | public function ver ($slug) | ||
{ | { | ||
if ($slug) { | if ($slug) { | ||
− | $this->noticia = | + | $this->noticia = $this->Articulos->buscar($slug); |
} | } | ||
} | } | ||
public function rss () | public function rss () | ||
{ | { | ||
− | $this->noticias = | + | $this->noticias = $this->Articulos->ultimos(); |
− | + | $this->set_response("view"); | |
} | } | ||
} | } | ||
</source> | </source> | ||
− | Lo que mencionamos arriba sobre | + | Lo que mencionamos arriba sobre el rehuso del código si vemos el método ultimos() del modelo Articulos nos sirve para crear un RSS, un [[KumbiaPHP_Framework_Versión_1.0_Spirit#views.2Fpartials.2F |Partial]] (widget) con los artículos recientes, etc. es decir donde necesitemos los últimos artículos. |
− | |||
− |