Diferencia entre revisiones de «Usuario:ManuelRomero/php/smarty/cesta»
De WikiEducator
< Usuario:ManuelRomero | php
Línea 47: | Línea 47: | ||
class Cesta { | class Cesta { | ||
protected $productos = array(); | protected $productos = array(); | ||
+ | |||
+ | //... | ||
+ | </source> | ||
+ | <!-- | ||
+ | |||
// Introduce un nuevo artículo en la cesta de la compra | // Introduce un nuevo artículo en la cesta de la compra | ||
Línea 88: | Línea 93: | ||
?> | ?> | ||
</source> | </source> | ||
+ | --> | ||
*Dentro de esta clase necesitamos acceder a la base de datos | *Dentro de esta clase necesitamos acceder a la base de datos | ||
*Esto implica que incluyamos incluyamos en el fichero '''''DB.php''''', así como añadir nuevo método en la clase DB.php. | *Esto implica que incluyamos incluyamos en el fichero '''''DB.php''''', así como añadir nuevo método en la clase DB.php. | ||
Línea 107: | Línea 113: | ||
public static function obtieneProducto($codigo) { | public static function obtieneProducto($codigo) { | ||
+ | </source> | ||
+ | <!-- | ||
$valores = array('cod'=>$codigo); | $valores = array('cod'=>$codigo); | ||
$sql = <<<FIN | $sql = <<<FIN | ||
Línea 123: | Línea 131: | ||
</source> | </source> | ||
− | + | --> | |
===Plantillas=== | ===Plantillas=== | ||
*Tenemos que modificar la plantilla de '''''productos.tpl''''', para añadir la presentación de los datos de la cesta | *Tenemos que modificar la plantilla de '''''productos.tpl''''', para añadir la presentación de los datos de la cesta | ||
Línea 133: | Línea 141: | ||
#cesta.tpl | #cesta.tpl | ||
*Las palntillas listaProductos y cesta las cargaremos en la plantilla de productos.tpl, usando la instrución de smarty '''''include file=plantilla.tpl'''''. | *Las palntillas listaProductos y cesta las cargaremos en la plantilla de productos.tpl, usando la instrución de smarty '''''include file=plantilla.tpl'''''. | ||
+ | <!-- | ||
*El código quedará de la siguiente manera | *El código quedará de la siguiente manera | ||
<source lang=php> | <source lang=php> | ||
Línea 174: | Línea 183: | ||
</source> | </source> | ||
− | + | --> | |
;listaProductos.tpl | ;listaProductos.tpl | ||
*Tendría el siguiente código | *Tendría el siguiente código | ||
+ | |||
<source lang=php> | <source lang=php> | ||
{foreach from=$productos item=producto} | {foreach from=$productos item=producto} | ||
+ | ...... | ||
+ | </source> | ||
+ | <!-- | ||
<p><form id='{$producto->getcodigo()}' action='producto.php' method='post'> | <p><form id='{$producto->getcodigo()}' action='producto.php' method='post'> | ||
<input type='hidden' name='cod' value='{$producto->getcodigo()}'/> | <input type='hidden' name='cod' value='{$producto->getcodigo()}'/> | ||
Línea 204: | Línea 217: | ||
</id> | </id> | ||
</source> | </source> | ||
− | + | --> | |
− | ===La lógica o el | + | ===La lógica o el código=== |
*Ahora vamos a ver que hemos tenido que modificar en el código | *Ahora vamos a ver que hemos tenido que modificar en el código | ||
*La parte de código la centramos en el fichero producto.php | *La parte de código la centramos en el fichero producto.php | ||
Línea 216: | Línea 229: | ||
<source lang=php> | <source lang=php> | ||
$cesta = Cesta::carga_cesta(); | $cesta = Cesta::carga_cesta(); | ||
+ | ..... | ||
+ | </source> | ||
+ | <!-- | ||
// Comprobamos si se quiere añadir un producto a la cesta | // Comprobamos si se quiere añadir un producto a la cesta | ||
if (isset($_POST['enviar'])) { | if (isset($_POST['enviar'])) { | ||
Línea 234: | Línea 250: | ||
} | } | ||
</source> | </source> | ||
+ | --> | ||
*Con esto ya tendríamos terminada la penúltima versión de nuestro trabajo | *Con esto ya tendríamos terminada la penúltima versión de nuestro trabajo | ||
*No olvidéis subir la cesta.png para que aparezca la imagen | *No olvidéis subir la cesta.png para que aparezca la imagen |
Revisión de 01:36 20 ene 2017
Probando el ejemplo
- Puedes ver esta parte del ejercicio ejecutándose en la web:
http://www.manuel.infenlaces.com/TiendaCesta/login.php
Nuevas especificaciones
- En esta nueva versión vamos a añadir la parte de la cesta
- Es decir que cuando seleccionemos un nuevo producto, añadamos ese producto a la cesta
- Para ello seleccionaremos o elegiremos productos de la lista de productos, y según los seleccionemos, se añadirán a la cesta.
- Esto modificará la plantilla de lo que antes solo eran los productos pues ahora nos aparecer en la parte de la derecha una cesta
- La cesta contendrá un listado de todos los productos que actualmente hemos comprado.
- La cesta, con su contenido, aparecerá en la pantalla de productos.
- De cada producto aparecerá su código y nombre corto (actualmente en la base de datos no hay nombres cortos), y el precio
- También aparecerá el total de la cesta.
- Para gestionar la cesta tendremos un objeto de la clase cesta: Cesta.php
- Por otro lado tenemos que modificar la plantilla de productos.tpl una platilla
Explicación del funcionamiento
- El siguiente diagrama de uso expone el funcionamiento de la nueva versión
- Par ver claro el escenario dibujamos el siguiente diagrama de uso
- Explicacion
- Usuario selecciona un nuevo producto
- Se incorpora el nuevo producto en la cesta (Cesta.php, BD.php y Producto.php)
- Se exporta el objeto cesta para la plantilla cesta.tpl
- Se exporta el usuario y lista de productos para la plantilla listaProductos.tpl
- Se carga la plantilla productos.tpl que incluirá las platillas cesta.tpl y listaProductos.tpl.
- En esta explicación ya hemos detallado los nuevos ficheros que vamos a incorporar en nuestro desarrollo, los cuales se exponen a continuación
Clases
- Cesta.php
- Vamos a crear una clase Cesta.php
- Una cesta va a ser un conjunto de productos que hemos comprado.
- Además podremos hacer las siguientes acciones:
- nuevo_articulo($codigo) //Añande un nuevo producto a la cesta
- get_productos()// Obtiene los artículos en la cesta
- coste()// Obtiene el coste total de los artículos en la cesta
- vacia // Devuelve true si la cesta está vacía
- guarda_cesta()// Guarda la cesta de la compra en la sesión del usuario
- carga_cesta() // Recupera la cesta de la compra almacenada en la sesión del usuario.
- Todos estos métodos los obtenemos a partir de las especificaciones o ejercicio realizado anteriormente.
- El objeto Cesta queda como se expresa en la siguiente imagen
<?php require_once('DB.php'); class Cesta { protected $productos = array(); //...
- Dentro de esta clase necesitamos acceder a la base de datos
- Esto implica que incluyamos incluyamos en el fichero DB.php, así como añadir nuevo método en la clase DB.php.
- Dentro de la clase Cesta.php, en el método nuevo artículo necesitamos recuperar los datos de un artículo, para ello creamos el método obtieneProducto($codigo) en la clase DB.php
- Este método a partir de un código de producto nos retorna un objeto de la clase producto.
- DB.php
- Como acabamos de ver a esta clase le añadimos un nuevo método
- Con ello la clase DB.php definitiva quedaría
- El código de este método
/*======================obtieneProducto ($codigo)====================================== Accion: obtiene los datos de un determinado producto cuyo codigo pasamos como argumento Parámetros: $codigo es el codigo del producto cuyos datos queremos Retorna un objeto de la clase producto con sus datos(cod, nombre_corto y PVP * ***********************************************************************************************/ public static function obtieneProducto($codigo) {
Plantillas
- Tenemos que modificar la plantilla de productos.tpl, para añadir la presentación de los datos de la cesta
- Para hacerlo más cómodo vamos a crear una plantilla contenedora que será productos.tpl, y en ella incluiremos por un lado la lista de productos que irá en una plantilla llamadda listaProductos.tpl, y los datos de la cesta que los aportará una plantilla llamada cesta.tpl
- Por lo tanto ahora tendremos tres ficheros para estas plantillas
- productos.tpl
- listaProductos.tpl
- cesta.tpl
- Las palntillas listaProductos y cesta las cargaremos en la plantilla de productos.tpl, usando la instrución de smarty include file=plantilla.tpl.
{include file="cesta.tpl"}
{include file="listaproducto.tpl"}
<form action='logoff.php' method='post'> <input type='submit' name='desconectar' value='Desconectar usuario {$usuario}'/> </form>
</div> </body> </html> </source>
-->
- listaProductos.tpl
- Tendría el siguiente código
{foreach from=$productos item=producto} ......
La lógica o el código
- Ahora vamos a ver que hemos tenido que modificar en el código
- La parte de código la centramos en el fichero producto.php
- Por un lado debemos cargar un objeto cesta con el contenido de la cesta
- El contenido de la cesta la guardamos en una variable de sesión
El código que implementamos para ello sería
$cesta = Cesta::carga_cesta(); .....
- Con esto ya tendríamos terminada la penúltima versión de nuestro trabajo
- No olvidéis subir la cesta.png para que aparezca la imagen