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:
{{cleanupbox
 
|image=[[Archivo:Information_icon4.png|45px]]
 
|texto ='''Este Artículo cumple con todos los requerimientos de los Kumbieros.'''<br />
 
}}
 
 
 
 
== Introducción ==
 
== Introducció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 proporciona un gran poder al momento que se necesita escalar, mantener y reusar código en una 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 difícilmente 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 que 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].
 
  
==El Modelo extiende el ActiveRecord==
+
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 intendible 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.
[http://www.kumbiaphp.com KumbiaPHP] usa [http://es.wikipedia.org/wiki/POO POO (Programación orientada a objetos)], así que [[Indice#ACTIVE_RECORD | ActiveRecord]] es una clase que ya lleva métodos listos para usar. Estos [[Consultas |métodos]] facilitan al usuario el manejo de las tablas de las bases de datos; entre ellos están los siguientes: find, find_all, save, update, etc.
 
  
El Modelo extiende la clase [[Indice#ACTIVE_RECORD | ActiveRecord]] para que el usuario pueda añadir sus propios métodos, y asi encapsular la lógica.
+
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 MVC.
  
 
== Un Buen Modelo ==
 
== Un Buen Modelo ==
Línea 35: Línea 24:
 
$today = date('now');
 
$today = date('now');
 
return $this->find('order: creat_at desc',
 
return $this->find('order: creat_at desc',
  "conditions: data <= $today",
+
  "conditions: data > $today",
 
  "limit: $limit");
 
  "limit: $limit");
 
 
Línea 42: Línea 31:
 
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 bd.articulos a WHERE MATCH (titulo,texto)  
+
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 38:
 
</source>
 
</source>
  
Normalmente este código muchos usuarios lo colocan en el controller quedando el mismo '''ilegible''', colocándolo como se muestra arriba queda muy limpia la implementación de los mismo en nuestros modelos en los controller.
+
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 ==
 
A continuación se muestra un controller donde se puede apreciar lo '''legible''' que queda nuestro controller si delegamos las funciones que corresponden a sus responsables dentro del [http://es.wikipedia.org/wiki/Modelo_Vista_Controlador Patrón MVC] que promueve [http://www.kumbiaphp.com KumbiaPHP].
 
 
 
<source lang=php>
 
<?php
 
class MiController extends AppController
 
{
 
    public function index ($id = 1)
 
    {
 
        $this->noticias = (new Articulos)->ver($id);
 
    }
 
    public function ver ($slug)
 
    {
 
        if ($slug) {
 
            $this->noticia = (new Articulos)->buscar($slug);
 
        }
 
    }
 
    public function rss ()
 
    {
 
        $this->noticias = (new Articulos)->ultimos();
 
        View::template(null); //mostramos solo la vista, sin el template
 
    }
 
}
 
</source>
 
 
 
Lo que mencionamos arriba sobre la '''re-utilización''' de código y característica fundamental de la [http://es.wikipedia.org/wiki/POO POO], 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.
 
 
 
[[Categoría:Tutoriales KumbiaPHP]]
 

Ten en cuenta que todas las contribuciones a KumbiaPHP Framework Wiki pueden ser editadas, modificadas o eliminadas por otros colaboradores. Si no deseas que las modifiquen sin limitaciones, no las publiques aquí.
Al mismo tiempo, asumimos que eres el autor de lo que escribiste, o lo copiaste de una fuente en el dominio público o con licencia libre (véase Proyecto:Derechos de autor para más detalles). ¡No uses textos con copyright sin permiso!

Para editar esta página, responde la pregunta que aparece abajo (más información):

Cancelar Ayuda de edición (se abre en una ventana nueva)

Plantilla usada en esta página: