Usuario:ManuelRomero/ProgramacionWeb/Distancia2018/Smarty/Ejercicios

De WikiEducator
Saltar a: navegación, buscar




Práctica hola mundo

  • La primera práctica es simplemente visualizar un usuario registrado
  • El la página principal un formulario para que inserte su nombre
  • Una vez que se ha registrado solo visualizaremos su nombre y un botón para volver a insertar nombre (Que vuelva a aparecer el formulario con la caja de texto)
  • No hay que guardar valores en variables
  • Incluimos un css para ver cómo se cargan desde la plantilla.

Registro1PHP.png

  • Si lo ha insertado visualizamos
Bienvenido a tu sitio web $nombreUsuario
  • Pasos:
  1. Cargamos con composer la librería de Smarty

Idioma no válido.

Necesita especificar un idioma como esto: <source lang="html4strict">...</source>

lenguajes soportados para sintaxis remarcada:

4cs, 6502acme, 6502kickass, 6502tasm, 68000devpac, abap, actionscript, actionscript3, ada, algol68, apache, applescript, apt_sources, arm, asm, asp, asymptote, autoconf, autohotkey, autoit, avisynth, awk, bascomavr, bash, basic4gl, bf, bibtex, blitzbasic, bnf, boo, c, c_loadrunner, c_mac, caddcl, cadlisp, cfdg, cfm, chaiscript, cil, clojure, cmake, cobol, coffeescript, cpp, cpp-qt, csharp, css, cuesheet, d, dcl, dcpu16, dcs, delphi, diff, div, dos, dot, e, ecmascript, eiffel, email, epc, erlang, euphoria, f1, falcon, fo, fortran, freebasic, freeswitch, fsharp, gambas, gdb, genero, genie, gettext, glsl, gml, gnuplot, go, groovy, gwbasic, haskell, haxe, hicest, hq9plus, html4strict, html5, icon, idl, ini, inno, intercal, io, j, java, java5, javascript, jquery, kixtart, klonec, klonecpp, latex, lb, ldif, lisp, llvm, locobasic, logtalk, lolcode, lotusformulas, lotusscript, lscript, lsl2, lua, m68k, magiksf, make, mapbasic, matlab, mirc, mmix, modula2, modula3, mpasm, mxml, mysql, nagios, netrexx, newlisp, nsis, oberon2, objc, objeck, ocaml, ocaml-brief, octave, oobas, oorexx, oracle11, oracle8, oxygene, oz, parasail, parigp, pascal, pcre, per, perl, perl6, pf, php, php-brief, pic16, pike, pixelbender, pli, plsql, postgresql, povray, powerbuilder, powershell, proftpd, progress, prolog, properties, providex, purebasic, pycon, pys60, python, q, qbasic, rails, rebol, reg, rexx, robots, rpmspec, rsplus, ruby, sas, scala, scheme, scilab, sdlbasic, smalltalk, smarty, spark, sparql, sql, stonescript, systemverilog, tcl, teraterm, text, thinbasic, tsql, typoscript, unicon, upc, urbi, uscript, vala, vb, vbnet, vedit, verilog, vhdl, vim, visualfoxpro, visualprolog, whitespace, whois, winbatch, xbasic, xml, xorg_conf, xpp, yaml, z80, zxbasic


{
   require:{
             "smarty/smarty":"~3.1"
           }
}
  1. creamos la estructura de directorios del proyecto
  2. creamos el fichero index.php
  3. creamos la plantilla paginaWeb.tpl
//index.php
<?php
//.....
require_once('Smarty.class.php');
$smarty = new Smarty;
$smarty->template_dir = '/web/smarty/smarty1/templates/';
$smarty->compile_dir = '/web/smarty/smarty1/templates_c/';
$smarty->config_dir = '/web/smarty/smarty1/configs/';
$smarty->cache_dir = '/web/smarty/smarty1/cache/';
 
session_start();
if (!$_SESSION['usuario']){
    $_SESSION['usuario']=$_POST['usuario'];
    echo "Valor de usuario ".$_SESSION['usuario'];
}
$smarty->assign('usuario',$_SESSION['usuario']);
 
$smarty->display('paginaWeb.tpl')
?>
//paginaWeb.tpl
 
<!DOCTYPE html>
 
<html>
    <head>
        <title>página de smarty</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
    </head>
    <body>
        {*Usando motor de plantillas smarty*}
 
        {if empty($usuario)}
        <form action="http://localhost/practicaSmarty/index.php" method="POST">
            Usuario
            <input type="text" name ="usuario"/>
            <input type =submit value="acceder">
        </form>
        {else}
            <h1>Bienvenido al sitio web {$usuario}</h1>
        {/if}
 
    </body>
</html>

Lista de productos usuario registrado

  • Primero el usuario se registra contra la bd
  • Una vez logueado visualizaremos su nombre
  • Debajo veremos una lista de los productos disponibles
  • Lo visualizamos en una lista de productos, cada uno con un botón para comprar. de los productos visualizamos el nombre corto y el precio