Desarrollo Mobile Sencha y Phonegap

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 224

Programacin Web

ndice
1

Introduccin al desarrollo web para mviles............................................................... 5


1.1

Introduccin............................................................................................................. 5

1.2

Instalacin de un servidor Web..............................................................................12

1.3

HTML.................................................................................................................... 20

1.4

CSS........................................................................................................................ 31

1.5

HTML 5................................................................................................................. 40

1.6

CSS3...................................................................................................................... 55

1.7

Ms informacin.................................................................................................... 66

Ejercicios - Introduccin al desarrollo web para mviles.......................................... 67


2.1

Ejercicio 1 - Estructura en HTML (0.6 puntos).....................................................67

2.2

Ejercicio 2 - Terminando la Web de ejemplo (0.6 puntos)....................................67

2.3

Ejercicio 3 - Estructura de HTML 5 (0.6 puntos)..................................................68

2.4

Ejercicio 4 - Canvas (0.2 puntos)...........................................................................69

2.5

Ejercicio 5 - Geolocalizacin (0.2 puntos)............................................................ 69

2.6

Ejercicio 6 - Almacenamiento Offline (0.3 puntos)...............................................69

2.7

Ejercicio 7 - CSS3 (0.5 puntos)............................................................................. 69

Introduccin a Sencha Touch..................................................................................... 71


3.1

Introduccin........................................................................................................... 71

3.2

Sencha Touch vs. JQuery Mobile.......................................................................... 72

3.3

Instalar Sencha Touch............................................................................................73

3.4

Estructura de carpetas............................................................................................ 74

3.5

Cdigo HTML bsico de una aplicacin............................................................... 75

3.6

Instanciar una aplicacin........................................................................................77

3.7

Comprobando los resultados..................................................................................79

3.8

Todo en un nico fichero....................................................................................... 80

3.9

Paneles y Layouts.................................................................................................. 80

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

3.10

Identificadores......................................................................................................82

3.11

Toolbars................................................................................................................83

3.12

Docked items........................................................................................................84

3.13

Botones.................................................................................................................85

Ejercicios - Introduccin a Sencha Touch..................................................................89


4.1

Ejercicio 1 - Estructura de la aplicacin (0.5 puntos)............................................89

4.2

Ejercicio 2 - Creacin de paneles (0.5 puntos)...................................................... 89

4.3

Ejercicio 3 - Barras de herramientas (1 punto)...................................................... 90

4.4

Ejercicio 4 - Botones (1 punto)..............................................................................90

Sencha Touch............................................................................................................. 92
5.1

Transiciones de cambio de vista............................................................................ 92

5.2

TabBar....................................................................................................................94

5.3

Carousel................................................................................................................. 95

5.4

MessageBox...........................................................................................................96

5.5

Formularios............................................................................................................ 98

Ejercicios - Sencha Touch........................................................................................ 103


6.1

Ejercicio 1 - Transiciones (1 punto).....................................................................103

6.2

Ejercicio 2 - Contenido de la ayuda (1 punto)..................................................... 103

6.3

Ejercicio 3 - Panel con Formulario (1 punto)...................................................... 104

Aspectos avanzados de Sencha Touch..................................................................... 105


7.1

Data Model...........................................................................................................105

7.2

Data Store.............................................................................................................107

7.3

Plantillas...............................................................................................................110

7.4

Data Views...........................................................................................................112

7.5

Listados................................................................................................................ 113

7.6

Formularios.......................................................................................................... 116

7.7

Ms informacin.................................................................................................. 120

Ejercicios - Aspectos avanzados de Sencha Touch..................................................122


8.1

Ejercicio 1 - Modelo y Almacn de datos (0.8 puntos)....................................... 122

8.2

Ejercicio 2 - Listado (0.6 puntos)........................................................................ 122

8.3

Ejercicio 3 - Crear y Editar notas (0.8 puntos).................................................... 123

8.4

Ejercicio 4 - Guardar y Borrar notas (0.8 puntos)............................................... 123

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Introduccin a jQuery Mobile.................................................................................. 125


9.1

Qu es jQuery Mobile?...................................................................................... 125

9.2

Pginas en jQuery Mobile....................................................................................128

9.3

Barras de herramientas.........................................................................................139

9.4

Formateo de contenido.........................................................................................145

10

Ejercicios - Introduccin a jQuery Mobile............................................................. 152

10.1

Ejercicio 1 - Inicio de la aplicacin....................................................................152

10.2

Ejercicio 2 - Pgina del autor ............................................................................ 152

10.3

Ejercicio 3 - Listado de libros............................................................................ 153

11

Aspectos avanzados de jQuery Mobile...................................................................154

11.1

Listados de elementos........................................................................................ 154

11.2

Formularios........................................................................................................ 164

12

Ejercicios - Aspectos avanzados de jQuery Mobile............................................... 181

12.1

Ejercicio 1: Listado de libros mejorado............................................................. 181

12.2

Ejercicio 2: Registro de usuarios........................................................................181

12.3

Ejercicio 3: Consumiendo servicios REST........................................................ 182

13

Multimedia..............................................................................................................183

13.1

Transmisin de Audio y vdeo........................................................................... 183

13.2

TV mvil y en Internet....................................................................................... 183

13.3

Formatos de audio.............................................................................................. 184

13.4

Estndares de vdeo............................................................................................185

13.5

Perfiles de vdeo................................................................................................. 187

13.6

Descarga progresiva de vdeo............................................................................ 189

13.7

Streaming de vdeo.............................................................................................191

13.8

Audio y vdeo en HTML 5.................................................................................195

13.9

Audio y Vdeo en Sencha touch.........................................................................198

13.10

Audio y Vdeo en JQuery Mobile.....................................................................198

13.11

Repositorios de vdeos......................................................................................199

13.12

Podcast..............................................................................................................200

14

Ejercicios - Multimedia.......................................................................................... 204

14.1

Ejercicio - Audio y vdeo en HTML (1 punto).................................................. 204

14.2

Ejercicio - Vdeo en JQuery Mobile y Sencha Touch (0.6 puntos)................... 204

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

14.3

Ejercicio - Cabecera MOOV (0.6 puntos)..........................................................204

14.4

Ejercicio - Podcast (0.8 puntos)......................................................................... 205

15

PhoneGap................................................................................................................206

15.1

Introduccin....................................................................................................... 206

15.2

Soporte............................................................................................................... 207

15.3

Cmo trabaja PhoneGap.....................................................................................208

15.4

Configuracin.....................................................................................................208

15.5

Configuracin con Android................................................................................208

15.6

Configuracin en otros sistemas........................................................................ 214

15.7

API de PhoneGap............................................................................................... 214

16

Ejercicios - PhoneGap............................................................................................ 221

16.1

Importar ejemplo PhoneGap (0.75 puntos)........................................................ 221

16.2

Hola Mundo con PhoneGap (0.75 puntos).........................................................221

16.3

Incorporando un proyecto de Sencha Touch (0.75 puntos)............................... 222

16.4

Usando la API de PhoneGap (0.75 puntos)........................................................222

17

Bibliografa............................................................................................................. 223

17.1

Libros................................................................................................................. 223

17.2

Enlaces............................................................................................................... 223

17.3

Twitter................................................................................................................ 224

17.4

Podcasts..............................................................................................................224

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

1. Introduccin al desarrollo web para mviles


1.1. Introduccin
La Web mvil es la misma Web que la de escritorio, utiliza la misma arquitectura bsica
y muchas de las mismas tecnologas. Pero existen claras diferencias que impiden que su
funcionamiento y manejo sea el mismo, como son: el tamao de la pantalla, las diferentes
formas de uso (tctil, teclado del mvil, etc.) y el ancho de banda.
Otra diferencia que se debera de tener en cuenta es que es "mvil". Accedemos a Internet
desde lugares en los que sera imposible hacerlo con un ordenador de sobremesa o incluso
un porttil. Esto influye tambin en el uso que le damos, se hacen ms bsquedas o
consultas, adems de que la informacin se debe de disponer de forma ms clara y
directa.
Debido a todo esto, al programar una Web para mvil debemos de tener en cuenta que ni
el contenido, ni la apariencia, ni la estructura de la web va a ser la misma que la que
podramos hacer para un ordenador de escritorio. Hemos de disear muy bien este tipo de
aplicaciones y orientarlas al uso principal que le va a dar el usuario. Para esto se suele
referir a la regla del 20%: el 80% del contenido del sitio web de escritorio no es vlido
para una web mvil. Por lo que hemos de centrarnos en ese 20% restante, averiguar cual
es, y optimizar nuestro sitio para este uso.
1.1.1. Aplicacin mvil vs. Aplicacin nativa
Los desarrolladores de aplicaciones nativas tienen la ventaja de poder usar funciones no
disponibles para la web mvil:
El uso de interfaces nativas que proveen los propios SDK como iPhone o Android.
El uso de bases de datos locales. Aunque en HTML 5 se pueden usar el
almacenamiento local, hay que reconocer que estas tecnologas estn ms avanzadas
en los sistemas nativos.
Notificaciones push. A esto se refiere con los avisos centralizados que muestran las
aplicaciones, an cuando estn ocultas. Una fuerte razn que no puede ser
implementada en una web mvil.
Geolocalizacin. Hemos visto algunos ejemplos de geolocalizacin a travs de
HTML5, pero que no acaban de alcanzar la misma experiencia de usuario que una
aplicacin mvil. Podemos interactuar con el mapa o con las funcionalidades
asociadas a la localizacin del usuario, pero no ir mucho ms all.
Soporte para cmara o vdeo. Las funciones multimedia estn perfectamente
acopladas a las aplicaciones nativas, pudiendo aadir funcionalidades especificas a
nuestra aplicacin.
Sin embargo estas diferencias cada vez se van haciendo menores:
5

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Gracias al uso de HTML5, CSS3 y JavaScript cada vez se pueden hacer ms cosas y
obtener mejores resultados.
Cada vez hay mejores frameworks de desarrollo para aplicaciones mviles, como
JQuery Mobile o Sencha Touch. Estos nos permiten crear webs con apariencia
cercana a las de las aplicaciones nativas, pero a su vez con toda la potencia de la Web.
Estos framework nos permiten adaptar el contenido segn el dispositivo usado y sus
posibilidades tcnicas: pantalla tctil, reproduccin de vdeos o resolucin de pantalla.
Por lo que podramos decir que una Web mvil es mucho ms adaptable (adems de
multiplataforma) que una aplicacin mvil.
La web sigue siendo el negocio principal de muchas empresas de Internet. El
desarrollo web no ha muerto por la inclusin de las aplicaciones mviles, sino que se
ve afectado por un proceso de cambio haca la adopcin de tecnologas nuevas como
HTML5.
La inclusin de la tecnologa PhoneGap tambin est recortando ms estas
diferencias. PhoneGap es la posibilidad de crear una aplicacin nativa instalable a
partir de una pgina Web mvil, permitiendo adems su distribucin en Android
Market o en la App Store. Adems estas tecnologas facilitan el uso de
funcionalidades del dispositivo mvil directamente a travs de cdigo JavaScript,
como puede ser el acceso a la cmara, acelermetro, geolocalizacin, listado de
contactos, comprobar el estado de la conexin, etc.

1.1.2. Reglas de usabilidad


A la hora de iniciar el desarrollo de una Web para mvil es importante tener en cuenta
una serie de reglas bsicas:
1. Reducir la cantidad de contenido
Las aplicaciones mviles deben de ser optimizadas dado que el espacio visual es mucho
ms limitado que en una pantalla de ordenador. Cada pxel cuenta, y no todo lo que es
vlido para una Web de escritorio lo es para una Web mvil.
Solo debemos de incluir el contenido y las caractersticas principales y ms importantes.
Los contenidos con menor importancia deben de ser eliminados, como contenidos
secundarios, normalmente localizados en columnas laterales.
La web mvil debe de estar enfocada a este contenido principal. Facilitar su lectura y
navegacin, as como mejorar los tiempos de carga reduciendo imgenes y contenidos.
2. Usar una sola columna
Las pginas Web anchas y con varias columnas dificultan la navegacin y lectura en un
dispositivo mvil. Incluso en los terminales mviles con pantallas ms grandes hay que
realizar zoom para moverse y ver bien el contenido. Esta es una prctica que debemos
evitar, pues tener que ir realizando zoom aade ms pasos a la navegacin, y en algunos
dispositivos no es tan fcil de realizar como en un iPhone.

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Lo mejor es tener nuestro contenido en una sola columna que use todo el ancho de la
pantalla. Para aadir contenido lo deberemos de hacer hacia abajo (o creando una pgina
nueva), nunca hacia los lados (o creando columnas). Esto nos asegura que el contenido se
va a visualizar correctamente, adems es mucho ms intuitivo realizar scroll hacia abajo
para ir leyendo.
3. Muestra los enlaces de navegacin de forma diferente
No pongas todos los enlaces de navegacin en la parte superior de la pantalla. Si hay
muchos desplazarn todo el contenido hacia abajo, y es posible que los tengas que poner
muy reducidos.
La pgina principal debera de contener los enlaces al resto del contenido junto con un
buscador (si fuese necesario). El contenido debera de estar en pginas secundarias bien
organizado. Por ejemplo, cuando un usuario entra en un sitio de eCommerce suelen tener
una categora de producto en mente que quiere consultar, la cual la podran encontrar
usando el buscador o directamente a partir del men. Es decir, la pgina principal debe
facilitar el acceso rpido a la informacin ms importante de la web.
Tambin hay otras opciones para colocar el men de navegacin, como una lista
desplegable o al final de la pgina. Son muy cmodas las barras de herramientas estticas
que ofrecen las opciones principales (volver a la pgina inicial, botones principales, etc.).
4. Minimiza la cantidad de datos solicitados
Escribir texto utilizando un terminal mvil es mucho ms difcil que hacerlo utilizando el
teclado de un ordenador de sobremesa. Adems los usuarios suelen escribir mucho ms
lento y cometer ms errores. Por estas razones tenemos que intentar minimizar la cantidad
de texto solicitado.
Una forma de conseguir esto es permitir almacenar los datos (usuario, contraseas,
configuracin, direcciones, etc.), o aprovechar algunas de las funcionalidades que
incorporan los dispositivos mviles (como veremos ms adelante).
5. Decide si necesitas ms de una Web para mvil
El tamao de pantalla, la capacidad de procesamiento y de usabilidad vara enormemente
de un terminal a otro. Por esta razn a veces debemos de considerar crear varios sitios
web con el mismo contenido pero adaptado a diferentes necesidades. Por ejemplo,
Facebook tiene m.facebook.com como sitio web principal para mviles, pero adems
tiene una versin optimizada para pantallas tctiles (touch.facebook.com) y una versin
optimizada para conexiones ms lentas (0.facebook.com).
6. Disea para pantallas tctiles, pero tambin para telfonos no-tctiles
La forma de navegar por las pginas web es muy diferente segn el dispositivo: pantallas
tctiles, trackball, joystick, teclado, etc. Estas caractersticas tambin son importantes a la
hora de realizar el diseo. Por ejemplo, la principal dificultad est en la seleccin y

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

pulsado sobre textos o enlaces pequeos. En las pantallas tctiles adems se dificulta
pulsar sobre elementos que estn muy juntos.
Por esta razn, los enlaces o elementos que puedan ser seleccionados deben de ocupar un
mayor espacio en pantalla, incluirlos en botones o cuadros ms grandes, que puedan ser
pulsados con facilidad.
7. Aprovecha las funcionalidades que incorporan los mviles
Los telfonos mviles tienen algunas ventajas sobre los PCs, las cuales pueden facilitar la
realizacin de algunas tareas. Algunas de estas funcionalidades aadidas son:
Realizar llamadas: puede parecer evidente pero es una funcionalidad muy til que los PCs
no pueden realizar tan fcilmente. Por esta razn debemos de aprovecharla para, por
ejemplo, llamar directamente al presionar sobre un nmero de telfono, facilitar el
contacto con un servicio tcnico, etc.
Uso de mapas y posicin actual: es posible dar la opcin al usuario de seleccionar una
direccin y que automticamente se abra en la aplicacin de mapas del dispositivo mvil.
Tambin es muy interesante el uso de la posicin actual para mostrar puntos de inters
cercanos, calcular rutas, etc.
Solicitud de informacin de forma innovadora: como por ejemplo los cdigos QR, que se
han usado en algunas campaas de publicidad, etc.
Al cumplir esta serie de reglas se incrementa el pblico que puede acceder a los
contenidos, creando sitios Web eficaces y haciendo la navegacin accesible desde ms
dispositivos.
1.1.3. Dominio
Existen diferentes alternativas sobre el dominio que podemos usar. En definitiva esta es
una decisin personal, pues todas ellas tienen sus ventajas e inconvenientes. La nica
recomendacin que se suele hacer es tener varias opciones disponibles, con la intencin
de facilitar al mximo el acceso.
Podemos tener un subdominio de nuestro sitio Web especializado para dispositivos
mviles. Por ejemplo, si nuestro sitio Web es www.midominio.com, el sitio para
dispositivos mviles podra ser m.midominio.com. Por ejemplo, Facebook tiene
disponibles los sitios m.facebook.com (como sitio web para dispositivos mviles) y
touch.facebook.com (para dispositivos tctiles).
Tambin podemos usar el dominio principal y diferenciar (desde el cliente o desde el
servidor) si se trata de un dispositivo mvil. En este caso el usuario accedera a la misma
direccin pero sera redirigido al sitio correspondiente.
Otra opcin es comprar un dominio ".mobi" (especial para web mvil) con el mismo
nombre que la web principal.
8

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Si optamos por dar diferentes opciones de acceso deberemos crear redirecciones 301 al
dominio principal seleccionado para manejar ese contenido, de la forma:
<?php
header("HTTP/1.1 301 Moved Permanently");
header("location:http://www.nueva_url.com");
?>

1.1.4. Deteccin del navegador


Un dilema a la hora de desarrollar contenidos para mviles es cmo diferenciar entre
dispositivos mviles y navegadores de escritorio. Esto se puede hacer fcilmente
mediante una funcin de comprobacin que nos indique el tipo de navegador que ha
solicitado la web. Una vez obtenido el navegador tenemos varias opciones, como se
comentaba en la seccin anterior: redireccionar al dominio correspondiente, o adaptar el
cdigo de nuestra pgina segn el cliente.
A continuacin se incluye una funcin en PHP que nos devuelve un nmero positio si
detecta que el navegador es un dispositivo mvil, y 0 en caso de ser un navegador de
escritorio.
public static function mobileBrowser()
{
$mobile_browser = '0';
//$_SERVER['HTTP_USER_AGENT'] -> el agente de usuario que est
// accediendo a la pgina.
if(preg_match('/(up.browser|up.link|mmp|symbian|smartphone|midp|wap|phone)/i',
strtolower($_SERVER['HTTP_USER_AGENT'])))
{
$mobile_browser++;
}
//$_SERVER['HTTP_ACCEPT'] -> Indica los tipos MIME que el cliente
puede recibir.
if((strpos(strtolower($_SERVER['HTTP_ACCEPT']),'application/vnd.wap.xhtml+xml')>0)
or
((isset($_SERVER['HTTP_X_WAP_PROFILE']) or
isset($_SERVER['HTTP_PROFILE']))))
{
$mobile_browser++;
}
$mobile_ua = strtolower(substr($_SERVER['HTTP_USER_AGENT'],0,4));
$mobile_agents = array(
'w3c
','acs-','alav','alca','amoi','audi','avan','benq','bird','blac',
'blaz','brew','cell','cldc','cmd-','dang','doco','eric','hipt','inno',
'ipaq','java','jigs','kddi','keji','leno','lg-c','lg-d','lg-g','lge-',
'maui','maxo','midp','mits','mmef','mobi','mot-','moto','mwbp','nec-',
'newt','noki','oper','palm','pana','pant','phil','play','port','prox',
'qwap','sage','sams','sany','sch-','sec-','send','seri','sgh-','shar',
'sie-','siem','smal','smar','sony','sph-','symb','t-mo','teli','tim-',
'tosh','tsm-','upg1','upsi','vk-v','voda','wap-','wapa','wapi','wapp',
'wapr','webc','winw','winw','xda','xda-');

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

//buscar agentes en el array de agentes


if(in_array($mobile_ua, $mobile_agents)) {
$mobile_browser++;
}
//$_SERVER['ALL_HTTP'] -> Todas las cabeceras HTTP
if(strpos(strtolower($_SERVER['ALL_HTTP']),'OperaMini')>0) {
$mobile_browser++;
}
if(strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'windows')>0) {
$mobile_browser=0;
}
return $mobile_browser;
}

Tambin existen libreras un poco ms completas para detectar el cliente usando cdigo
PHP. En este ejemplo se cubren los casos ms bsicos, y funcionar en la mayora de
ellos. Pero si queremos una librera ms completa podemos consultar:
http://detectmobilebrowsers.mobi/
La deteccin del navegador tambin la podemos hacer desde el cliente y usando
diferentes lenguajes, como por ejemplo JavaScript. En la direccin
http://detectmobilebrowsers.com/ tenemos disponibles libreras que realizan esta funcin
en multitud de lenguajes, como JavaScript, ASP, ASP.NET, C#, Apache, JSP, JQuery,
Perl, etc.
1.1.5. Ejemplos de Webs para mviles
Cuando se empieza en el desarrollo de webs para dispositivos mviles es bueno buscar
inspiracin, ir a ver que ha hecho gente con ms experiencia en el campo. A continuacin
se incluye una pequea lista de ejemplos:
http://m.diesel.com

http://m.flickr.com/

10

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

http://www.vspink.mobi/

http://mobile.walmart.com/

http://m.marksandspencer.com/

http://iphonetoolbox.com/dailywallpaper

En todos de ellos debemos de considerar la adaptacin que se ha hecho del contenido


entre la web de escritorio y la web para dispositivos mviles. En la siguiente imagen se
puede ver una comparacin en la que vara la disposicin. Pero como hemos dicho, los
11

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

cambios no son nicamente de disposicin, tenemos que recordar la regla del 20%.

1.2. Instalacin de un servidor Web


En la programacin Web, una de las herramientas principales que necesitamos es un
servidor Web o servidor HTTP. Este es el encargado de compilar el cdigo (segn el
lenguaje de programacin que utilicemos) y enviarlo al cliente utilizando el protocolo de
transferencia HTTP.
Dado que instalar un servidor Web completo y configurarlo correctamente es una tarea
bastante costosa, para el desarrollo y testeo de aplicaciones en local se suele utilizar un
servidor XAMPP. Este es un paquete software de fcil instalacin que incluye todo lo
necesario para la ejecucin de un servidor Web.
Es independiente de plataforma, software libre (licencia GNU), y consiste principalmente
en la base de datos MySQL, el servidor web Apache y los intrpretes para lenguajes de
script: PHP y Perl. El nombre proviene del acrnimo formado por X (para cualquiera de
los diferentes sistemas operativos), Apache, MySQL, PHP y Perl. Actualmente XAMPP
est disponible para Microsoft Windows (WAMPP), GNU/Linux (LAMPP), Solaris y
MacOS X (MAMPP).
1.2.1. XAMPP para Linux
Para su instalacin en Linux tendremos que seguir los siguientes pasos:
1. En primer lugar descargamos el software desde:
http://www.apachefriends.org/en/xampp-linux.html
2. Abrimos una consola y ejecutamos:

12

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

sudo tar xvfz xampp-linux-1.7.7.tar.gz -C /opt

Ahora ya tenemos instalado el servidor en la ruta /opt/lampp.


3. Para inicializar el servidor escribimos:
sudo /opt/lampp/lampp start

Veremos algo como:


Starting XAMPP 1.7.7...
LAMPP: Starting Apache...
LAMPP: Starting MySQL...
LAMPP started.

Con esto ya tenemos listo nuestro servidor Apache con MySQL.


4. Para comprobar que todo ha ido correctamente abrimos un navegador y escribimos la
direccin http://localhost, debera de abrirse una pgina similar a la siguiente:

El directorio raz de Apache es /opt/lampp/htdocs, que ser donde colocaremos nuestras


pginas Web.
El servidor viene por defecto sin ninguna opcin de seguridad activada (ya que se va a
usar en local para pruebas), pero si quisiramos activarlas tendramos que escribir:

13

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

sudo /opt/lampp/lampp security

Por ltimo, para detener el servidor Web simplemente ejecutamos en una consola:
sudo /opt/lampp/lampp stop

1.2.2. XAMPP para Windows


Los pasos para instalar XAMPP en Windows son los siguientes:
1. Descargamos la ltima versin del software desde:
http://www.apachefriends.org/en/xampp-windows.html
Existen diferentes opciones de descarga, la ms sencilla y la que seguiremos aqu es
utilizar el instalador.
2. Ejecutamos el instalador utilizando los valores por defecto:

3. Despus de la instalacin abrimos el Panel de Control de XAMPP (se encuentra en el


men de Inicio > Programas > XAMPP). Desde aqu podemos iniciar y detener cada
uno de los servicios individualmente.

14

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

4. Para comprobar que el servidor est instalado correctamente abrimos un navegador y


escribimos la direccin http://localhost/ (o tambin http://127.0.0.1/), donde se
nos abri una pgina web como la siguiente:

Si nos avisa el Firewall del sistema tendremos que desbloquear o permitir el acceso a
Apache.
En Windows, el directorio raz de Apache para el contenido Web est en
C:\xampp\htdocs, que ser donde colocaremos nuestras pginas Web.
El servidor viene por defecto sin ninguna opcin de seguridad activada (ya que se va a
usar en local para pruebas), pero estas opciones se pueden configurar directamente desde
un navegador accediendo a la direccin http://localhost/security/.
1.2.3. Instalar un servidor Web para Mac

15

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Existen ciertas ventajas del uso de un Mac para el desarrollo de aplicaciones para
mviles. Para empezar, el sistema operativo viene con un servidor web Apache instalado.
El navegador por defecto, Safari, renderiza correctamente las aplicaciones basadas en
WebKit. Y, por su puesto, tiene un excelente simulador para iOS como parte de Xcode.
Si queremos instalar un servidor XAMPP para Mac podemos acceder a la direccin
http://www.apachefriends.org/en/xampp-macosx.html y seguir los pasos de instalacin,
muy similares a los ya vistos para Linux y Windows.
Para este ejemplo vamos a explicar la configuracin del servidor Apache que viene con el
sistema operativo. En primer lugar abrimos las Preferencias del Sistema y vamos al
panel Sharing, en el cual deberemos de habilitar la opcin Web Sharing:

Dependiendo de la versin del sistema operativo que tengamos, aparecer un botn para
abrir la carpeta con el contenido Web y un enlace desde donde podremos comprobar que
el servidor se est ejecutando correctamente.
Si lo queremos comprobar nosotros directamente, desde el navegador tendremos que
acceder a la direccin IP de nuestra mquina en la red seguida de nuestro nombre de
usuario, como podemos ver en la imagen inferior:

16

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Si estuvisemos utilizando un servidor XAMPP desde el navegador podramos haber


accedido directamente a la direccin: http://localhost.
El directorio para el contenido Web se encuentra normalmente dentro de la carpeta
principal con el nombre de Sites:

1.2.4. Acceso mediante un dispositivo mvil real


Si estamos trabajando con el servidor Web disponible en Mac, podremos acceder a
nuestras pginas Webs de forma externa simplemente conectndonos a la misma red
WiFi. Para esto nos tendremos que asegurar que en el ordenador que hace de servidor no
se est ejecutando ningn Firewall que pueda bloquear el acceso desde un cliente remoto.
La direccin que tendremos que utilizar ser igual que la que usaramos desde un
navegador ejecutado en el mismo ordenador: la direccin IP del servidor en esa red
seguida de nuestro nombre de usuario, como podemos ver en la imagen inferior:

17

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Si nuestro servidor est corriendo en una mquina con Linux o Windows, entonces
tendremos que seguir los siguientes pasos. En primer lugar tambin nos tendremos que
asegurar de que no se est ejecutando ningn Firewall que pueda bloquear el acceso (si
fuera as tendramos que darle acceso). A continuacin obtendremos la direccin IP del
servidor. Para esto abrimos un terminal y ejecutaremos el comando ipconfig (desde
Windows) o ifconfig (desde Linux), obteniendo un resultado similar a:

Utilizando esta direccin IP y estando conectados a la misma red WiFi, ya podremos


acceder a nuestro servidor Web desde un dispositivo mvil externo. Simplemente
tendremos que escribir la direccin formada como http://172.16.125.128/mi_web.
Donde en primer lugar colocamos la direccin IP seguida del nombre de la carpeta donde
se encuentre nuestro proyecto Web.
Es posible que obtengamos un error de seguridad como el siguiente:

18

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En este caso tendramos que abrir el fichero httpd-xampp.conf que contiene la


configuracin
de
nuestro
servidor
XAMPP.
Lo
encontraremos
en
C:\xampp\apache\conf\extra en nuestro servidor Windows y en la ruta
/opt/lampp/etc/extra en Linux. Al final de este fichero podremos ver el siguiente trozo
de texto:
<LocationMatch
"^/(?i:(?:xampp|security|licenses|phpmyadmin|webalizer|server-status|server-info))">
Order deny,allow
Deny from all
Allow from 127.0.0.0/8
ErrorDocument 403 /error/HTTP_XAMPP_FORBIDDEN.html.var
</LocationMatch>

Si no nos importa la seguridad (pues es una red local), podemos abrir el acceso a todos los
usuarios cambiando la cuarta lnea por Allow from All, quedando de la forma:
<LocationMatch
"^/(?i:(?:xampp|security|licenses|phpmyadmin|webalizer|server-status|server-info))">
Order deny,allow
Deny from all
Allow from all
ErrorDocument 403 /error/HTTP_XAMPP_FORBIDDEN.html.var
</LocationMatch>

Tendremos que reiniciar nuestro servidor Apache para que los cambios tengan efecto (ver
en las secciones anteriores) y ya tendremos acceso desde nuestro dispositivo mvil.
1.2.5. Instalacin del SDK de Android
Si queremos utilizar el emulador de Android para testear nuestras Webs tendremos que
instalar el SDK de Android completo. Para esto descargamos el software desde
http://developer.android.com/sdk/index.html y procedemos a su instalacin. Este
proceso simplemente requiere que descomprimamos el archivo descargado en una carpeta
y ejecutemos el SDK Manager (tools/android) para empezar a trabajar.
Para poder realizar simulaciones y visualizar nuestras pginas Web tendremos que crear

19

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

un dispositivo virtual de Android (Android Virtual Device o AVD).


Si utilizamos Eclipse como entorno de desarrollo, podemos instalar el plugin de Android
para Eclipse (ADT Plugin), el cual lo podremos encontrar en la direccin
http://developer.android.com/sdk/eclipse-adt.html. Este plugin integrar el SDK y
nuestro simulador en Eclipse.
1.2.6. Instalar Xcode
Si trabajamos con el sistema operativo de Mac podremos hacer uso del IDE Xcode y de
los emuladores de iPhone e iPad que incorpora para testear nuestras aplicaciones en local.
Este software lo podemos descargar desde el Apple Developer Center accediendo a la
direccin http://developer.apple.com/xcode/.
1.2.7. Simuladores y Emuladores
Los simuladores solo tratan de reproducir el comportamiento, para que el resultado se
parezca al que obtendramos con una ejecucin real. Los emuladores, por su parte,
modelan de forma precisa el dispositivo (hardware y S.O.), de manera que este funcione
como si estuviese siendo usado en el aparato original.
Podemos encontrar algunos simuladores online mediante los cuales realizar pruebas
rpidas de nuestros proyectos, como:
iPhone 4 Simulator (http://iphone4simulator.com)
Test iPhone (http://www.testiphone.com)
iPhone Tester (http://iphonetester.com)
Opera Mini Simulator (http://www.opera.com/developer/tools/mini/)
Emuladores para Nokia N70 y Sony K750 (http://mtld.mobi/emulator.php)
Para poder usar estos simuladores tendremos que tener nuestro proyecto en un servidor
Web para poder acceder a travs de la direccin de localhost o de la IP.
Para una completa gua de los emuladores disponibles podemos consultar:
http://www.mobilexweb.com/emulators.

1.3. HTML
HTML, siglas de HyperText Markup Language (lenguaje de marcado de hipertexto), es
el lenguaje de marcado predominante para la elaboracin de pginas web. Es usado para
describir la estructura y el contenido en forma de texto, as como para complementar el
texto con objetos tales como imgenes. El cdigo HTML se escribe en forma de
etiquetas, mediante las cuales podemos describir la estructura lgica y apariencia del
contenido. La apariencia que podemos describir con HTML est bastante limitada, pero el
cdigo se puede complementar y mejorar mediante el uso de otros lenguajes como

20

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

JavaScript o CSS.
1.3.1. Editores HTML
El lenguaje HTML puede ser creado y editado con cualquier editor de textos bsico,
como puede ser Gedit en Linux o el Bloc de notas de Windows. Existen adems otros
editores para la realizacin de sitios web con caractersticas WYSIWYG (What You See
Is What You Get, o en espaol: lo que ves es lo que obtienes). Estos editores permiten
ver el resultado de lo que se est editando en tiempo real, a medida que se va
desarrollando el documento. Ahora bien, esto no significa una manera distinta de realizar
sitios web, sino que una forma un tanto ms simple ya que estos programas, adems de
tener la opcin de trabajar con la vista preliminar, tiene su propia seccin HTML, la cual
va generando todo el cdigo a medida que se va trabajando. Algunos ejemplos de editores
son Adobe Dreamweaver, KompoZer o Microsoft FrontPage.
Estos editores aceleran o facilitan la creacin de cdigo HTML, pero en algunas
ocasiones tambin generan mucho ms cdigo del necesario (como es el caso de
Microsoft FrontPage). Lo ideal es tener un control total sobre el cdigo que se escribe y
utilizar estos editores slo como una pequea ayuda. Tambin podemos utilizar otro tipo
de editores que simplemente comprueben que el cdigo HTML escrito es correcto (que
las etiquetas y atributos son correctos, las etiquetas se cierran correctamente, etc.).
1.3.2. Etiquetas
Las etiquetas HTML deben de ir encerradas entre corchetes angulares <>, y pueden ser
de dos tipos:
Se abren y se cierran, como por ejemplo: <b>negrita</b> o <p>texto</p>.
Slo se abren, como <br/> o <hr/>.
En caso de que no cerremos una etiqueta que deba ser cerrada se producir un error en la
estructura del documento y probablemente tambin genere errores en la visualizacin.
Hay etiquetas que adems pueden contener atributos, en este caso los atributos se deben
de colocar en la etiqueta de inicio, de la forma:
<etiqueta atributo1="valor1" atributo2="valor2">...</etiqueta>

O para las etiquetas de solo apertura:


<etiqueta atributo1="valor1" atributo2="valor2"/>

1.3.3. Estructura bsica de una Web


Un documento HTML comienza con la etiqueta <html> y termina con </html>. Dentro
del documento (entre las etiquetas de principio y fin de html) hay dos zonas bien

21

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

diferenciadas: el encabezamiento, delimitado por <head> y </head>, que sirve para


incluir definiciones iniciales vlidas para todo el documento; y el cuerpo, delimitado por
<body> y </body>, donde reside la informacin del documento.
Las etiquetas bsicas o mnimas son:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Ejemplo</title>
</head>
<body>
Hola mundo!
</body>
</html>

La primera lnea es el DOCTYPE, o el tipo de documento que viene a continuacin. En


este caso se usa el estndar de HTML 4.01 (el ltimo estndar adoptado en 1999, ya que
HTML5 a fecha de 2011 sigue siendo un borrador). La siguiente etiqueta, <html>, define
el inicio del documento HTML, e indica que lo que viene a continuacin debe ser
interpretado como cdigo HTML. Como podemos ver en la ltima lnea, se cierra la
etiqueta </html>.
1.3.4. Elementos de la cabecera
La cabecera contiene informacin sobre el documento que no se muestra directamente al
usuario. Como por ejemplo el ttulo de la ventana del navegador, los metadatos o la hoja
de estilo utilizada. Dentro de la cabecera <head></head> podemos encontrar:
<title></title>: define el ttulo de la pgina. Por lo general el ttulo aparece en la barra
de ttulo encima de la ventana.
<link/>: para vincular el sitio con hojas de estilo (ver la seccin de CSS para ms
informacin):
<link rel="stylesheet" href="style.css" type="text/css"/>

El atributo rel es requerido y describe el tipo de documento enlazado (en este caso
una hoja de estilo). El atributo type es simplemente indicativo del tipo de hoja de
estilo enlazada (en este caso CSS).
<style></style>: se utiliza para aadir definicin de estilo en lnea. No es necesario
colocarlo si se va a utilizar una hoja de estilo externa usando la etiqueta <link/> (que
es lo ms habitual y recomendable). El uso correcto sera de la forma:
<html>
<head>
...
<style type="text/css">
Estilos CSS
</style>
</head>
<body></body>

22

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

</html>

Para ms informacin ver la seccin CSS del manual.


<meta/>: para indicar metadatos como la descripcin de la web, los keywords, o el
autor:
<meta name="description" content="Descripcin de la web" />
<meta name="keywords" content="key1,key2,key3" />
<meta name="author" content="Nombre del autor" />

<script></script>: permite incluir un script en la Web. El cdigo se puede escribir


directamente entre las etiquetas de <script> o cargar desde un fichero externo,
indicando mediante el atributo src=url del script la direccin del fichero. Se
recomienda incluir el tipo MIME en el atributo type, que en el caso de cdigo
JavaScript sera text/javascript. Ejemplos:
<script src="fichero.js" type="text/javascript"></script>
<script type="text/javascript">
Cdigo de un script integrado en la pgina
</script>

Cuando usamos el atributo src el contenido de estas etiquetas est vaco (no
encierra nada), esto es porque lo carga directamente desde el fichero indicado.
1.3.5. Etiquetas bsicas HTML
Las etiquetas HTML que utilizaremos para crear el contenido de nuestra pgina deben de
ir dentro de la seccin <body></body>.
Algunas de las etiquetas HTML que ms se suelen utilizar son:
<h1></h1> a <h6></h6>: encabezados o ttulos del documento con diferente
relevancia, siendo <h1> la cabecera de mayor nivel.
<p></p>: definicin de un prrafo.
<br/>: salto de lnea.
<b></b>: texto en negrita (etiqueta desaprobada. Se recomienda usar la etiqueta
<strong></strong>).
<i></i>: texto en cursiva (etiqueta desaprobada. Se recomienda usar la etiqueta
<em></em>).
<s></s>: texto tachado (etiqueta desaprobada. Se recomienda usar la etiqueta
<del></del>).
<u></u>: texto subrayado.
<center></center>: texto centrado.
<pre></pre>: texto preformateado, respeta los espacios y saltos de lnea.
<sup></sup>: Superndice
<sub></sub>: Subndice
<blockquote></blockquote>: Indica una cita textual, se representa como un prrafo
indexado con respecto al margen.

23

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<hr/>: Lnea horizontal, usada, por ejemplo, para separar diferentes secciones.
<!-- comentario -->: Comentarios en HTML. El texto del comentario no ser visible
en el navegador.
<span></span>: Esta etiqueta no aplica ningn formato por si misma, sino que
provee una forma de definir un estilo o formato a un trozo de texto. Se utiliza junto
con una hoja de estilo. Por ejemplo, lo podemos utilizar para marcar palabras en algn
color o con algn formato especial.

1.3.6. Listas
Para definir una lista utilizamos las siguientes etiquetas:
<ol></ol>: Lista ordenada (con numeracin).
<ul></ul>: Lista con puntos (o vietas).
<li></li>: Elemento de una lista (tanto numerada como no numerada). Esta etiqueta
debe de estar entre las etiquetas <ol></ol> o <ul></ul>.
Ejemplo de lista:
<ol>
<li>Elemento 1</li>
<li>Elemento 2</li>
</ol>

1.3.7. Tablas
Las tablas se definen bsicamente mediante tres etiquetas:
<table></table>: define una tabla.
<tr></tr>: fila de una tabla, debe de estar dentro de las etiquetas de una tabla.
<td></td>: celda de una tabla, debe estar dentro de una fila.
Ejemplo de una tabla:
<table>
<tr>
<td>Fila
<td>Fila
</tr>
<tr>
<td>Fila
<td>Fila
</tr>
</table>

1 izquierda</td>
1 derecha</td>
2 izquierda</td>
2 derecha</td>

Adems tambin podemos utilizar la etiqueta <th> en lugar de <td> para indicar una
celda de cabecera, de esta forma el contenido ser resaltado en negrita y en un tamao
ligeramente superior al normal.
En la etiqueta de apertura <table> podemos utilizar los siguientes atributos:

24

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

border=num: Ancho del borde de la tabla en puntos. Si indicamos border=0


tendremos una tabla cuyas divisiones no sern visibles, esta propiedad se suele utilizar
para distribuir los elementos en una pgina Web.
cellspacing=num: Espacio en puntos que separa las celdas que estn dentro de la
tabla.
cellpadding=num: Espacio en puntos que separa el borde de cada celda y el
contenido de esta.
width=num: Indica la anchura de la tabla en puntos o en porcentaje en funcin del
ancho de la ventana. Si no se indica este parmetro, el ancho depender de los
contenidos de las celdas.
height=num: Indica la altura de la tabla en puntos o en porcentaje en funcin del
alto de la ventana. Si no se indica este parmetro, la altura depender de los
contenidos de las celdas.
Este atributo tambin se puede utilizar en las etiquetas <tr> para indicar la altura de
cada fila de forma individual.

En las etiquetas de apertura de celda (<td> o <th>) podemos utilizar los siguientes
atributos:
align=pos: Indica como se debe alinear el contenido de la celda, a la izquierda
(left), a la derecha (right), centrado (center) o justificado (justify).
valign=pos: Indica la alineacin vertical del contenido de la celda, en la parte
superior (top), en la inferior (bottom), o en el centro (middle).
rowspan=num: Indica el nmero de filas que ocupar la celda. Por defecto ocupa
una sola fila. Este atributo se utiliza para crear celdas multifila, es decir, una celda
que por ejemplo ocupe 3 filas. Tendremos que tener en cuenta que esa celda no se
deber de definir en las siguientes 2 filas (para esas filas se definir una celda menos).
colspan=num: Indica el nmero de columnas que ocupar la celda. Por defecto
ocupa una sola columna. Este atributo se utiliza para crear celdas multicolumna, es
decir, una celda que por ejemplo ocupe 3 columnas. Tendremos que tener en cuenta
que en esa fila tendremos que definir 2 celdas menos.
width=num: Indica la anchura de la columna en puntos o en porcentaje en funcin
del ancho de la ventana. Si no se indica este parmetro, el ancho depender del
tamao de los contenidos.
1.3.8. Cajas (etiqueta <div>)
La etiqueta <div></div> permite crear cajas contenedoras. Estas cajas se utilizan para
organizar la disposicin de los elementos en la pgina. Es muy sencillo indicar su
posicin de forma absoluta o relativa en la pgina y crear divisiones del espacio para
distribuir los elementos. Estas cajas pueden contener cualquier tipo de elemento (texto,
imgenes, etc.) u otras etiquetas <div> para crear subdivisiones. Se recomienda su uso
junto con CSS, en vez de la etiqueta <table>, cuando se desea alinear contenido. Para ms
informacin consultar la seccin sobre CSS.

25

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

1.3.9. Enlaces
Los enlaces permiten vincular partes del documento con otros documentos o con otras
partes del mismo documento. Por ejemplo, que al pulsar con el ratn sobre un texto o
sobre una imagen se nos redirija a una nueva Web con un contenido diferente.
Para crear un enlace se utiliza la etiqueta <a href=""></a> cuyo atributo href establece
la direccin URL a la que apunta el enlace. Por ejemplo, un enlace a la Wikipedia sera de
la forma:
<a href="es.wikipedia.org">Wikipedia</a>

Tambin se pueden crear enlaces sobre otros objetos, tales como imgenes, de la forma:
<a href="direccin_URL"><img src="imagen.jpg"/></a>

La etiqueta de enlace <a> tambin permite el atributo target="_blank", mediante el cual


indicamos que el enlace se tiene que abrir en una nueva ventana o en una pestaa nueva
del navegador.
1.3.10. Imgenes
Para incluir una imagen se utiliza la etiqueta <img src= alt=/>, la cual requiere el
atributo src con la ruta en la que se encuentra la imagen. Es conveniente poner siempre
el atributo alt=texto alternativo, el cual indica el texto a mostrar en caso de no poder
cargar la imagen y tambin se utiliza para opciones de accesibilidad.
Por ejemplo, para cargar una imagen de cabecera:
<img src="cabecera.jpg" alt="Imagen de cabecera"/>

Adems existen otros atributos interesantes como width y height para redefinir el
ancho y la altura de la imagen.
1.3.11. Formularios
Los formularios permiten solicitar informacin al visitante de una pgina Web. Estn
compuestos por campos de diferente tipo, cuya informacin se enviar a una direccin
URL (indicada en el cdigo) al pulsar el botn de envo.
La declaracin de formulario queda recogida por las etiquetas <form></form>, los
cuales deben encerrar la definicin de todos los campos del formulario. En la etiqueta de
apertura <form> tenemos que indicar los atributos bsicos:
action=: Entre comillas se indica la accin a realizar al enviar el formulario. En
general se indicar el nombre de un fichero alojado en el servidor, el cual se encargar

26

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

de procesar la informacin. Aunque tambin se le puede indicar una direccin de


correo para que enve directamente todo el contenido, de la forma:
mailto:direccion_de_correo.
method= (post o get): Indica el mtodo de transferencia de las variables. El mtodo
post enva los datos de forma no visible, mientras que el mtodo get los adjunta a
la URL a la que se redirige.
enctype= : Especifica el tipo de codificacin de la informacin enviada. Con
method=get no se realiza codificacin, solo se cambian caracteres especiales como
el espacio, por lo que no es necesario indicar enctype. Cuando el valor del atributo
"method" es "post", podemos utilizar los siguientes valores:
application/x-www-form-urlencoded: Es el valor predeterminado. Codifica todos
los caracteres antes de enviarlos.
multipart/form-data: Es requerido al enviar archivos mediante un formulario. No
codifica la informacin.
text/plain: No codifica la informacin, solo cambia los espacios por el smbolo
+.

Tipos de campos bsicos


Para aadir campos al formulario se utiliza la etiqueta <input/>, esta etiqueta debe de
tener siempre dos atributos:
name=: Indica el nombre que se asigna a un determinado campo. Este nombre no
aparece visible en la Web, pues se utiliza para poder distinguir cada campo al enviar
la informacin al servidor o por correo. Es como si fuera el nombre de la variable a la
que se asigna el valor del campo.
type=: Indica el tipo de campo a utilizar. Puede ser de muchos tipos: text,
password, checkbox, radio, file, hidden, submit, reset.
A continuacin se describen ms detalladamente los diferentes tipos de campos <input/>
segn su valor type:
type=text: campo de tipo texto de una lnea. Sus atributos son:
maxlenght=: Seguido de un valor que limitar el nmero mximo de caracteres.
size=: Seguido de un valor que limitar el nmero de caracteres a mostrar en
pantalla. A diferencia de maxlenght este atributo no limita la longitud del texto
que se puede introducir, sino que modifica el tamao visible del campo.
value=: Indica el valor inicial del campo.

type=password: Este campo funciona exactamente igual que el de tipo text, pero
ocultar el texto introducido cambiando las letras por asteriscos o puntos. Sus
atributos son los mismos que para text.
type=checkbox: Este campo mostrar una casilla cuadrada que nos permitir
marcar opciones de una lista (podremos marcar varias opciones a la vez). Para indicar
que varias casillas pertenecen al mismo grupo se les debe de dar el mismo nombre
para el atributo name. El texto que queramos que aparezca a continuacin de la

27

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

casilla del checkbox se tendr que escribir despus de cerrar la etiqueta <input/>.
Sus atributos son:
value=: Define el valor que ser enviado si la casilla est marcada.
checked: Este atributo es opcional, y hace que la casilla aparezca marcada por
defecto. No necesita indicarle ningn valor.
Ejemplo:
<input type="checkbox" name="option1" value="leche"/> Leche<br/>
<input type="checkbox" name="option1" value="pan" checked/> Pan<br/>
<input type="checkbox" name="option1" value="queso"/> Queso<br/>

type=radio: El campo se elegir marcando de entre varias opciones una casilla


circular. Al marcar una casilla el resto de casillas de ese grupo de desmarcarn
automticamente. Para indicar que varias casillas pertenecen al mismo grupo se les
debe de dar el mismo nombre para el atributo name (ver ejemplo). Adems
debemos de indicar:
value=: Define el valor que ser enviado si la casilla est marcada.
checked: Este atributo es opcional, y hace que la casilla aparezca marcada por
defecto. Solo se podr usar para una casilla. No necesita indicarle ningn valor.
Ejemplo:
<input type="radio" name="group1" value="leche"/> Leche<br/>
<input type="radio" name="group1" value="pan" checked/> Pan<br/>
<input type="radio" name="group1" value="queso"/> Queso<br/>

type=file: El atributo file permite al usuario subir archivos. Necesitaremos un


programa que gestione estos archivos en el servidor mediante un lenguaje diferente al
HTML. El nico atributo opcional que podemos utilizar es size= mediante el cual
podremos indicar la anchura visual de este campo. Ejemplo:
<input type="file" name="datafile" size="40"/>

type=hidden: Este valor no puede ser modificado, pues permanece oculto. Se suele
utilizar para enviar al mtodo encargado de procesar el formulario algn dato
adicional necesario para su procesamiento. Para indicar el valor de este campo
utilizamos el atributo: value = "valor".
type=submit: Representa el botn de Enviar. Al pulsar este botn la informacin
de todos los campos se enviar realizando la accin indicada en <form>. Mediante el
atributo:
value=texto: podemos indicar el texto que aparecer en el botn.
type=reset: Al pulsar este botn se borra el contenido de todos los campos del
formulario. Mediante el atributo:
value=texto: podemos indicar el texto que aparecer en el botn.

Campos de Seleccin
Mediante la etiqueta <select></select> podemos crear listas de opciones, que nos

28

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

permitirn seleccionar entre una o varias de ellas. Sus atributos son:


name=: Nombre del campo.
size=: Nmero de opciones visibles a la vez. Si se indica 1 se presentar como un
men desplegable, si se se indica mas de uno aparecer como una lista con barra de
desplazamiento.
multiple: Permite seleccionar mas de un valor para el campo.
Las diferentes opciones de la lista se indicarn mediante la etiqueta <option></option>.
El nombre que se visualizar debe de indicarse dentro de estas etiquetas. Mediante el
atributo value= podemos indicar el valor que se enviar con el formulario. Tambin
podemos utilizar el atributo selected para indicar la opcin seleccionada por defecto. Si
no lo especificamos, siempre aparecer como seleccionado el primer elemento de la lista.
<select name="Colores" multiple>
<option value="r">Rojo</option>
<option value="g">Verde</option>
<option value="b">Azul</option>
</select>
<select name="Colores" SIZE="1">
<option value="r">Rojo</option>
<option value="g" selected>Verde</option>
<option value="b">Azul</option>
</select>

reas de texto
Mediante las etiquetas <textarea></textarea> podemos crear un campo de texto de
mltiples lneas. Los atributos que podemos utilizar son:
name=: Nombre del campo.
cols=num: Nmero de columnas de texto visibles.
rows=num: Nmero de filas de texto visibles.
1.3.12. Eventos
Los eventos permiten ejecutar acciones cuando sucede un determinado evento o se realiza
una determinada accin. La forma de definirlos es similar a los atributos
(evento=accin), la accin har referencia a una funcin o mtodo en lenguaje
JavaScript. Algunos de los eventos que podemos utilizar son:
onload: se activa cuando el navegador termina de cargar todos los elementos de la
pgina.
onunload: se activa al cerrar una pgina.
onclick: cuando se presiona el botn del ratn sobre un elemento.
ondblclick: se activa al hacer doble clic sobre un elemento.
onmousedown: se activa al presionar el botn del ratn (mientras que est
presionado).
onmouseup: cuando el botn del ratn es liberado.

29

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

onmouseover: se dispara cuando el cursor del ratn pasa sobre un elemento.


onmousemove: cuando se mueve el cursor del ratn mientras est sobre un elemento.
onmouseout: se activa cuando el cursor del ratn sale fuera de un elemento (sobre el
que estaba).
onfocus: ocurre cuando un elemento recibe el enfoque (el cursor de escritura), ya sea
con el puntero o con mediante la tecla tabulador.
onblur: se dispara cuando un elemento pierde el enfoque (ya sea por hacer clic fuera
o por presionar la tecla tabulador).
onkeypress: ocurre cuando se presiona una tecla (dentro de un elemento, por ejemplo
un campo de escritura).
onkeydown: se dispara cuando una tecla es presionada (dentro de un elemento)
onkeyup: cuando una tecla es soltada.
onsubmit: se activa cuando un formulario es enviado.
onreset: ocurre cuando un formulario es reseteado.
onselect: cuando el usuario selecciona un texto en un campo de texto.
onchange: ocurre cuando un control pierde el enfoque y su valor ha sido modificado
desde que recibi el enfoque.

Ejemplo de uso:
<script type="text/javascript">
function saveText() {
// acciones JavaScript
}
</script>
<textarea id="myarea" cols="80" rows="15" onkeyup="saveText()"></textarea>

1.3.13. Smbolos HTML


Los caracteres especiales como signo de puntuacin, letras con tilde o diresis, o
smbolos del lenguaje; se deben convertir en entidades HTML para que se muestren
correctamente en un navegador. La siguiente es una lista de caracteres espaoles junto
con algunos smbolos especiales y su correspondiente entidad HTML:

&aacute;

&Aacute;

&eacute;

&Eacute;

&iacute;

&Iacute;

&oacute;

&Oacute;

&uacute;

&Uacute;

&uuml;

&Uuml;

&ntilde;

&Ntilde;

espacio en blanco &nbsp;

&euro;

30

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

< (Menor que)

&lt;

> (Mayor que)

&gt;

&

&amp;

(grados)

&deg;

Algunos servidores realizan esta conversin automticamente, pero en general es


aconsejable escribir los smbolos directamente. Para obtener una lista mucho ms
completa de smbolos podemos buscar en Google: HTML symbols o visitar la siguiente
direccin http://www.ascii.cl/htmlcodes.htm.

1.4. CSS
El nombre hojas de estilo en cascada viene del ingls Cascading Style Sheets, del que
toma sus siglas. CSS es un lenguaje usado para definir la presentacin o la apariencia de
un documento estructurado escrito en HTML o XML (y por extensin en XHTML). CSS
se cre para separar el contenido de la forma, a la vez que permite a los diseadores
mantener un control mucho ms preciso sobre la apariencia de las pginas. El W3C
(World Wide Web Consortium) es el encargado de formular la especificacin de las hojas
de estilo que sirven de estndar para los navegadores.
En versiones antiguas de HTML se deba de aadir el formato dentro de las propias
etiquetas, para indicar por ejemplo su color o tamao. Esto obligaba a tener que
especificar el mismo formato en todas las etiquetas para tener un diseo consistente,
adems, al cambiar un formato tambin haba que cambiarlo para todas las etiquetas.
Cuando se utiliza CSS, las etiquetas HTML no deberan proporcionar informacin sobre
cmo sern visualizadas. La informacin de la hoja de estilo ser la que especifique cmo
se han de mostrar: color, fuente, alineacin del texto, tamao, etc.
Las ventajas de utilizar CSS (u otro lenguaje de estilo) son:
Control centralizado de la apariencia de un sitio web completo, con lo que se agiliza
de forma considerable la actualizacin del mismo.
Los navegadores permiten a los usuarios especificar su propia hoja de estilo local, que
ser aplicada a un sitio web, con lo que aumenta considerablemente la accesibilidad.
Por ejemplo, personas con deficiencias visuales pueden configurar su propia hoja de
estilo para aumentar el tamao del texto o remarcar ms los enlaces.
Una pgina puede disponer de diferentes hojas de estilo segn el dispositivo que la
muestre o, incluso, a eleccin del usuario. Por ejemplo, para ser impresa o mostrada
en un dispositivo mvil.
El documento HTML en si mismo es ms claro de entender y se consigue reducir
considerablemente su tamao.
1.4.1. Adjuntar una hoja de estilo
La informacin de estilo puede ser adjuntada de tres formas diferentes:
Hoja de estilo externa: es una hoja de estilo que est almacenada en un archivo

31

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

diferente al archivo HTML (por ejemplo llamado estilo.css). Esta es la manera de


programar ms potente y la que deberemos de utilizar por defecto, porque separa
completamente las reglas de formateo para la pgina HTML. La hoja de estilo debe de
ser enlazada con el cdigo HTML de la forma:
<html>
<head>
<link rel="stylesheet" type="text/css" href="estilo.css"/>
...
</head>
...

Hoja de estilo interna: es una hoja de estilo que est incrustada dentro del
documento HTML. En general, la nica vez que se usa una hoja de estilo interna, es
cuando se quiere diferenciar con algn estilo uno de los ficheros HTML de nuestra
Web. Este cdigo debe de estar incluido en la seccin de cabecera y entre las etiquetas
<style>. Las etiquetas de comentario <!-- ... --> sirven para que los navegadores
antiguos, que no soportan CSS, no incluyan ese texto en el cuerpo de la pgina. La
forma de incluir este cdigo sera de la forma:
<html>
<head>
<STYLE type="text/css">
<!-H1 {color:blue; text-align:center}
// -->
</STYLE>
</head>
...

Estilo en lnea (inline): es un mtodo para insertar el lenguaje de CSS directamente


dentro de una etiqueta HTML. Esta manera de proceder no es totalmente adecuada. El
incrustar la descripcin del formateo dentro del documento de la pgina Web, a nivel
de cdigo, se convierte en una manera larga, tediosa y poco elegante de resolver el
problema de la programacin de la pgina. Este modo de trabajo se podra usar de
manera ocasional si se pretende aplicar un formateo con prisa, al vuelo. La forma de
incluir un estilo inline sera:
<h1 style="color:blue; text-align:center">...</h1>

1.4.2. Definicin de estilos para etiquetas HTML


Si lo que queremos es dar formato o redefinir una etiqueta HTML existente, usaramos la
sintaxis:
etiqueta {
estilo CSS 1;
estilo CSS 2;
...
}

32

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En "etiqueta" pondramos el nombre de la etiqueta (por ejemplo h1, p, etc. pero sin
los signos < >) y los estilos que definiran esa etiqueta iran encerrados entre las llaves
{...}.
Tambin podemos redefinir varias etiquetas a la vez, separndolas por comas, de la
forma:
etiqueta1, etiqueta2, etiqueta3 {
estilos CSS
}

O redefinir etiquetas dentro de otras etiquetas. En este caso el estilo CSS solo se
aplicar cuando la etiqueta redefinida se encuentre dentro de la etiqueta contenedora:
contenedor etiqueta {
estilos CSS
}

Por ejemplo, una etiqueta <span> dentro de una seccin <p>:


p span {
estilos CSS
}

1.4.3. Identificadores y Clases


A veces tenemos varias etiquetas del mismo tipo pero queremos aplicar diferentes estilos
segn donde estn. Para esto usamos los identificadores y las clases.
La principal diferencia entre ellos es que los identificadores tienen que ser nicos en todo
el documento HTML mientras que las clases pueden repetirse todas las veces que
queramos. Los identificadores se suelen usar con etiquetas "neutras" como <div> o
<span> para marcar partes de un documento y despus aplicar diferentes estilos a cada
una (como por ejemplo identificar la cabecera, un logotipo, el men principal, etc.).
En el siguiente ejemplo podemos ver como podemos indicar el identificador o la clase de
una etiqueta HTML. Esto se hace con los parmetros id y class respectivamente, y se
pueden aplicar a cualquier etiqueta:
<div id="capitulo2">
<p>...</p>
<p class="parrafogris">....</p>
<p>...</p>
<p class="parrafogris">....</p>
</div>

En este ejemplo capitulo2 sera una seccin nica marcada en el documento en la cual
podemos aplicar un estilo concreto. El estilo de la clase parrafogris se aplicara sobre
las etiquetas p indicadas.

33

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En nuestra hoja de estilos, para indicar los estilos que definen un identificador tenemos
que escribir el nombre del identificador precedido por una almohadilla #, de la forma:
#identificador {
estilos CSS
}

Esta definicin de estilos se puede combinar con lo que hemos visto en la seccin
anterior. Por ejemplo, para aplicar un estilo en concreto a la etiqueta etiqueta1 que est
dentro del identificador1:
#identificador1 etiqueta1 {
estilos CSS
}

Para aplicar estilos a clases es parecido pero precediendo el nombre de la clase con un
punto . en vez de una almohadilla. Por ejemplo:
.clase {
estilos CSS
}

La definicin de una clase tambin la podemos combinar con lo que hemos visto en la
seccin anterior. Adems tambin podemos aplicar los estilos de la clase slo a una
determinada etiqueta:
etiqueta1.clase1 {
estilos CSS
}

En este caso slo se aplicara el estilo a las etiquetas "etiqueta1" que se marque que son
de la clase "clase1", por ejemplo: <etiqueta1 class=clase1>...</etiqueta1>. Si
intentramos aplicar esta clase a una etiqueta diferente no funcionara.
1.4.4. Estilos CSS bsicos
La sintaxis bsica para definir un estilo es:
atributo: valor;

Los diferentes estilos siempre se separan con punto y coma, y despus del nombre se
pone dos puntos (y no un igual =, que es un error tpico al confundirse con el HTML).
Muchos de los valores que podemos aplicar a un atributo de estilo son unidades de
medida, por ejemplo, el valor del tamao de un margen o el tamao de la fuente. Las
unidades de medida que podemos utilizar son: pixels (px), puntos (pt), centmetros (cm) y
pulgadas (in).
A continuacin se incluye un resumen de los principales estilos CSS y los valores que se
34

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

les pueden aplicar:


FUENTES:
color: valor RGB o nombre de color
Ejemplos: color: #009900; color: red;
Sirve para indicar el color del texto. Lo admiten casi todas las etiquetas de HTML. No
todos los nombres de colores son admitidos en el estndar, es aconsejable entonces
utilizar el valor RGB. Algunos de los principales nombres de colores son: white,
black, gray, blue, red, green o yellow, para ms nombres podemos consultar la
direccin http://www.w3schools.com/cssref/css_colornames.asp.
font-size: xx-small|x-small|small|medium|large|x-large|xx-large|Unidades CSS
Ejemplos: font-size: 12pt; font-size: x-large;
Sirve para indicar el tamao de las fuentes de manera ms rgida y con mayor
exactitud.
font-family: serif | sans-serif | cursive | fantasy | monospace | Etc.
Ejemplos: font-family: arial,helvetica; font-family: fantasy;
Con este atributo indicamos la familia de tipografa del texto. Los primeros valores
son genricos (serif, sans-serif, etc.), es decir, los navegadores las comprenden y
utilizan las fuentes que el usuario tenga en su sistema.
Tambin se pueden definir con tipografas normales. Si el nombre de una fuente tiene
espacios se utilizan comillas para que se entienda bien.
font-weight: normal | bold | bolder | lighter | 100 | 200 | 300 | ... | 900
Ejemplos: font-weight: bold; font-weight: 200;
Sirve para definir la anchura de los caracteres, o dicho de otra manera, para poner
negrita con total libertad.
Normal y 400 son el mismo valor, as como bold y 700.
font-style: normal | italic | oblique
Ejemplos: font-style: normal; font-style: italic;
Es el estilo de la fuente, que puede ser normal, itlica u oblicua. El estilo "oblique" es
similar al "italic".
PRRAFOS:
line-height: normal | unidades CSS
Ejemplos: line-height: 12px; line-height: normal;
El alto de una lnea, y por tanto, el espaciado entre lneas. Es una de esas
caractersticas que no se podan modificar utilizando HTML.
text-decoration: none | underline | overline | line-through
Ejemplos: text-decoration: none; text-decoration: underline;
Establece la decoracin de un texto, si est subrayado, sobre-rayado o tachado.
text-align: left | right | center | justify
Ejemplos: text-align: right; text-align: center;
Sirve para indicar la alineacin del texto. Es interesante destacar que las hojas de
estilo permiten el justificado de texto, aunque recuerda que no tiene por que funcionar
en todos los sistemas.

35

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

text-indent: Unidades CSS


Ejemplos: text-indent: 10px; text-indent: 2in;
Un atributo que sirve para hacer sangrado o mrgenes en las pginas.
text-transform: capitalize | uppercase | lowercase | none
Ejemplos: text-transform: none; text-transform: capitalize;
Nos permite transformar el texto, para que tenga la primera letra en maysculas de
todas las palabras, o todo en maysculas o minsculas.

FONDO:
background-color: Un color, con su nombre o su valor RGB
Ejemplos: background-color: green; background-color: #000055;
Sirve para indicar el color de fondo de un elemento de la pgina.
background-image: El nombre de la imagen con su camino relativo o absoluto
Ejemplos: background-image: url(mrmol.gif); background-image:
url(http://www.url.com/fondo.gif)
Permite colocar una imagen de fondo en cualquier elemento de la pgina.
CAJAS (<div> o <table>):
width: Unidades CSS | Porcentaje
height: Unidades CSS | Porcentaje
Ejemplos: width: 50px; width: 100%; height: 15px;
Permiten indicar el ancho y altura de un elemento. Se pueden aplicar sobre muchos
elementos, como tablas, etiquetas div, imgenes, prrafos p, etc. Con algunas
etiquetas no funciona, tampoco sirve para indicar espaciado (padding), bordes o
mrgenes.
margin-left: Unidades CSS
Ejemplos: margin-left: 1cm; margin-left: 0,5in;
Indica el tamao del margen izquierdo.
margin-right: Unidades CSS
Ejemplos: margin-right: 5%; margin-right: 1in;
Define el tamao del margen derecho.
margin-top: Unidades CSS
Ejemplos: margin-top: 0px; margin-top: 10px;
Indica el tamao del margen superior.
margin-bottom: Unidades CSS
Ejemplos: margin-bottom: 0pt; margin-top: 1px;
Indica el tamao del margen inferior.
margin: <arriba> <derecha> <abajo> <izquierda> | <arriba> <derecha> <abajo> |
<arriba-abajo> <izquierda-derecha> | <los 4 mrgenes>
Ejemplos: margin: 4px 2px 1px 2px; margin: 4px;
Tambin podemos utilizar el estilo margin para indicar todos los mrgenes a la vez,
esta etiqueta nos permite indicarle desde 4 valores (para cada uno de los mrgenes),
hasta 1 valor (para aplicarlo sobre todos los mrgenes).
padding-left: Unidades CSS

36

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Ejemplos: padding-left: 0.5in; padding-left: 1px;


Indica el espacio insertado, por la izquierda, entre el borde del elemento-continente y
el contenido de este. Es parecido a el atributo cellpadding de las tablas. El espacio
insertado tiene el mismo fondo que el fondo del elemento-continente.
padding-right: Unidades CSS
Ejemplos: padding-right: 0.5cm; padding-right: 1pt;
Indica el espacio insertado, en este caso por la derecha, entre el borde del
elemento-continente y el contenido de este. Es parecido a el atributo cellpadding de
las tablas. El espacio insertado tiene el mismo fondo que el fondo del
elemento-continente.
padding-top: Unidades CSS
Ejemplos: padding-top: 10pt; padding-top: 5px;
Indica el espacio insertado, por arriba, entre el borde del elemento-continente y el
contenido de este.
padding-bottom: Unidades CSS
Ejemplos: padding-bottom: 0.5cm; padding-bottom: 1pt;
Indica el espacio insertado, en este caso por abajo, entre el borde del
elemento-continente y el contenido de este.
padding: <arriba> <derecha> <abajo> <izquierda> | <arriba> <derecha> <abajo> |
<arriba-abajo> <izquierda-derecha> | <los 4 mrgenes>
Ejemplos: padding: 4px 2px 1px 2px; padding: 4px;
Al igual que para margin, esta etiqueta nos permite indicarle desde 4 valores
(espaciado hasta cada uno de los bordes por separado), hasta 1 valor (para indicar el
mismo espaciado hasta todos los bordes).
border-color: color RGB o nombre de color
Ejemplos: border-color: red; border-color: #ffccff;
Para indicar el color del borde del elemento de la pgina al que se lo aplicamos. Se
puede poner colores por separado con los atributos border-top-color,
border-right-color, border-bottom-color, border-left-color.
border-style: none | dotted | solid | double | groove | ridge | inset | outset
Ejemplos: border-style: solid; border-style: double;
El estilo del borde, los valores significan: none=ningn borde, dotted=punteado,
solid=solido, double=doble borde, desde groove hasta outset son bordes con varios
efectos 3D.
border-width: Unidades CSS
Ejemplos: border-width: 10px; border-width: 0.5in;
El tamao del borde del elemento al que lo aplicamos.
border: <grosor> <tipo> <color>
Ejemplo: border: 2px solid red;
De esta forma podemos indicar las tres propiedades del borde a la vez. Tambin
podemos utilizar border-top, border-right, border-bottom y border-left para indicar
estas tres propiedades para un borde en concreto.
float: none | left | right
Ejemplo: float: right;

37

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Sirve para alinear un elemento a la izquierda o la derecha haciendo que el texto se


agrupe alrededor de dicho elemento.
clear: none | right | left
Ejemplo: clear: right;
Indica que no se permiten elementos por ese lado del objeto. Por ejemplo, si tenemos
varias cajas una a continuacin de otra, al poner "clear:left" en la ltima caja, esta
pasara a la siguiente lnea.

1.4.5. Pseudo-clases
Una pseudo-clase te permite tener en cuenta diferentes condiciones o eventos al definir
una propiedad para una etiqueta HTML, por ejemplo si un enlace ha sido visitado o si el
cursor del ratn est sobre un elemento. Algunas de las pseudo-clases que podemos
utilizar son:
a:link - enlace que no ha sido explorado por el usuario.
a:visited - se refiere a los enlaces ya visitados.
a:active - enlace seleccionado con el ratn.
a:hover - enlace con el puntero del ratn encima, pero no seleccionado.
a:focus - enlace con el foco del sistema. Tambin puede ser usado para un input.
p:first-letter - primera letra de un prrafo.
p:first-line - primera lnea de un prrafo.
Utilizando estos elementos podemos configurar por ejemplo:
a:hover { color: blue; }
a:visited { color: darkgreen; }
p:first-letter {color: green; font-size: x-large;}

1.4.6. Capas
Normalmente la posicin de los elementos de una pgina es relativa, es decir, depende de
los dems elementos de la pgina. Por ejemplo, un prrafo estar ms abajo si antes de l
hay ms prrafos o elementos. Debido a esto, normalmente cuando se quera colocar
elementos en un sitio concreto, se recurra al uso de tablas (invisibles, solo para
estructurar).
Con CSS podemos colocar los elementos en posicin absoluta, es decir, indicando el
tamao y coordenadas exactas en las que queremos que se coloque. Para organizar la
disposicin en una Web con CSS se suele usar el elemento <div>. Adems se le suele dar
un identificador nico a cada uno, mediante el cual, desde la hoja de estilo, podemos
configurar su disposicin. Tambin podemos colocar estos elementos con posicin
relativa a otro elemento que lo contenga, por ejemplo, un <div> dentro de otro.
Es comn en el diseo Web crear contenedores <div> generales en una posicin absoluta
o centrados en la pgina, con un tamao definido, los cuales se utilizarn para contener y

38

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

disponer el resto de elementos de nuestra Web. Estos otros elementos se pueden alinear
de forma sencilla con una alineacin relativa a sus contenedores. Por ejemplo un
contenedor para la cabecera que contenga un par de contenedores para la disposicin de
logotipo y el texto de cabecera.
Distribucin
Para indicar el tipo de distribucin o disposicin de un elemento lo hacemos mediante el
atributo position: valor. El cual puede tomar los valores:
absolute: La posicin del elemento no depende de ninguna otra etiqueta. Esta posicin
se calcula desde la esquina superior izquierda de la pgina.
fixed: Al igual que el anterior la posicin es absoluta, pero el elemento se queda fijo
en el sitio al hacer scroll.
relative: Posicin relativa a su elemento contenedor. Es la propiedad predeterminada.
static: Al igual que el anterior la posicin es relativa, pero no podemos redimensionar
(por ejemplo) el objeto.
Posicin
Para indicar la posicin concreta de una capa utilizamos los atributos: top, bottom, left y
right, de la forma:
top: <posicin>;
left: <posicin>;

Normalmente slo se utilizan un par de ellos, como top y left, o botton y right. La
posicin se especifica mediante unidades de CSS, como por ejemplo en px, aunque
tambin admite porcentajes.
Un ejemplo de la definicin de una capa sera:
#micapa {
position: absolute;
top: 200px;
left: 150px;
width: 175px;
height: 175px;
border: solid 1px blue;
text-align: center;
color: gray;
}

En nuestro documento HTML tendremos un elemento definido de la forma: <div


id=micapa> ... </div>, dentro del cual colocaremos texto u otros elementos.
Orden
A veces tenemos varias capas, unas por encima de otras, y queremos especificar un orden,
para poder controlar las ocultaciones entre capas. Para esto usamos el z-index, de la
forma:

39

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

z-index: <ndice>;

Las capas con un ndice de Z-index mayor aparecern por encima de las capas con un
z-index menor.

1.5. HTML 5
La quinta revisin del lenguaje de programacin HTML pretende remplazar al actual
(X)HTML, corrigiendo problemas con los que los desarrolladores web se encuentran, as
como redisear el cdigo y actualizndolo a nuevas necesidades que demanda la web de
hoy en da.

Actualmente se encuentra en modo experimental, lo cual indica la misma W3C; aunque


ya es usado por mltiples desarrolladores web por sus avances, mejoras y ventajas.
A diferencia de otras versiones de HTML, los cambios en HTML5 comienzan aadiendo
semntica y accesibilidad implcitas. Establece una serie de nuevos elementos y atributos
que reflejan el uso tpico de los sitios web modernos. Algunos de ellos son tcnicamente
similares a las etiquetas <div> y <span>, pero tienen un significado semntico, como por
ejemplo <nav> (bloque de navegacin del sitio web) o <footer>. Otros elementos
proporcionan nuevas funcionalidades a travs de una interfaz estandarizada, como los
elementos <audio> y <video>.
Algunos elementos de HTML 4.01 han quedado obsoletos, incluyendo elementos
puramente de presentacin, como <font> y <center>, cuyos efectos se deben de realizar
utilizando CSS. Tambin hay un renovado nfasis en la importancia del scripting DOM
para el comportamiento de la web.
1.5.1. Navegadores que lo soportan
Actualmente, de los navegadores de escritorio, el que mayor soporte da es Google
Chrome, seguido muy de cerca por Mozilla Firefox y Apple Safari. El que menor
compatibilidad ofrece es Internet Explorer.
Para comprobar la compatibilidad de un navegador podemos visitar la Web
http://www.html5test.com/ donde se realiza un test de todas las funcionalidades de
HTML5.
1.5.2. Doctype

40

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

El doctype es el encargado de indicarle al navegador el tipo de documento que est


abriendo, con el fin de renderizar la pagina de manera correcta. Por ejemplo, el doctype
de HTML 4 es:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">

Para HTML 5 el doctype se ha simplificado mucho y adems es compatible con las


versiones anteriores de HTML:
<!DOCTYPE html>

1.5.3. Mejor estructura


Hasta ahora se utilizaba de forma abusiva la etiqueta <div> y las tablas para estructurar
una web en bloques. El HTML5 nos brinda nuevas etiquetas que perfeccionan esta
estructuracin. Estas nuevas etiquetas introducen un nuevo nivel semntico que hace que
la estructura de la web sea ms coherente y fcil de entender. Adems los navegadores
podrn darle ms importancia a determinadas secciones, facilitndole adems la tarea a
los buscadores, as como cualquier otra aplicacin que interprete sitios Web. En la
siguiente imagen se puede ver una comparacin entre la estructuracin realizada con
HTML (hasta la versin 4) y HTML 5:

41

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Las Webs se dividirn en los siguientes elementos:


<section></section>: Se utiliza para representar una seccin general dentro de un
documento o aplicacin, como un captulo de un libro. Puede contener subsecciones y
si lo acompaamos de las etiquetas <h1>..<h6> podemos estructurar mejor toda la
pgina creando jerarquas del contenido, algo muy favorable para el buen
posicionamiento web. Por ejemplo:
<section>
<h1>Introduccin al elemento section</h1>
<p>El elemento section se usa para agrupar contenido relacionado entre
si.</p>
<p>...</p>
</section>

<article></article>: Se usa para definir contenido autnomo e independiente, con la

42

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

intencin de ser reutilizable de modo aislado. El elemento article puede contener uno
o varios elementos section. Si por ejemplo nuestro contenido puede ser redistribuido
como RSS y sigue manteniendo ntegro su significado, entonces, probablemente es un
elemento article. De hecho, el elemento article est especialmente indicado para
sindicacin. El elemento article es especialmente til para posts en blogs, noticias en
prensa digital, comentarios y posts en foros.
La especificacin de HTML5 aade adems que el elemento article debe ser usado
por widgets autnomos como; calculadoras, relojes, marcos de clima y cosas por el
estilo. Hay que analizar si el contenido de un widget es autnomo, independiente y
puede ser reutilizable o incluso sindicado.
<aside></aside>: Representa una seccin de la pgina que abarca un contenido no
directamente relacionado con el contenido que lo rodea, por lo que se le puede
considerar un contenido independiente. Dentro de este elemento pueden incluirse:
elementos publicitarios, barras laterales, grupos de elementos de la navegacin,
efectos tipogrficos, u otro contenido que se considere separado del contenido
principal de la pgina.
<header></header>: Es la cabecera de la pgina o de una seccin. Existe una
diferencia clave entre el elemento header y el uso habitual del trmino header (o
cabecera) utilizado comnmente para situar los elementos del encabezado de un sitio
web.
Una pgina web debe definir un header principal donde normalmente ir el logo o el
nombre del sitio y seguramente un men de navegacin, pero adems puede y
debe definir otros elementos <header> dentro de los elementos <section>:
<section>
<header>
<h1>Cabecera se seccin</h1>
</header>
<p>...</p>
</section>

<nav></nav>: Contiene informacin sobre la navegacin por el sitio web,


usualmente una lista de enlaces. Este elemento debe de ser utilizado solo para la
navegacin principal del sitio y no para enlaces externos por ejemplo. Normalmente
el elemento nav aparece dentro de un elemento header o footer.
<footer></footer>: Representa el pi de una seccin o la parte inferior de una pgina
Web, contiene informacin acerca de la pgina/seccin que poco tiene que ver con el
contenido de la pgina, como el autor, el copyright, la fecha de ltima modificacin,
etc. Igual que con la etiqueta <header>, este elemento tambin se puede utilizar dentro
de una seccin para indicar informacin como: quien lo ha escrito, informacin de
propiedad intelectual, enlaces, etc.

Es muy importante tener en cuenta que estas etiquetas no indican su posicin en la pgina
Web, sino su valor semntico. Por ejemplo, las etiquetas header, footer o aside no indican
que esos elementos tengan que ir en la parte superior, inferior o lateral del contenido
principal, sino que indican su funcin en esa seccin o en esa pgina.

43

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Adems debemos tener en cuenta que estas nuevas etiquetas se comportan igual que una
etiqueta de caja <div> por lo que podemos aplicarles los mismos estilos CSS. Podemos
redefinir la propia etiqueta o aplicarle una clase, por ejemplo:
header { width: 100%; padding: 10px; margin-bottom: 20px; }
.webheader { height: 30px; border: 1px solid gray; background-color:
silver; }
.sectionheader { font-size: 20px; }

1.5.4. Formularios
La estructura de los formularios con HTML 5 no vara con respecto a las anteriores de
HTML. Pero s que se aaden muchos nuevos tipos de campos que podemos utilizar, cada
uno especfico para cada tipo de dato.
En el caso de que utilicemos estas caractersticas y el navegador no sea compatible,
simplemente las ignorar sin causarnos mayores problemas. Tambin podemos detectar si
el navegador soporta una determinada caracterstica y en caso negativo emularla mediante
cdigo JavaScript (para ms informacin ver la seccin Detectar funcionalidades de
HTML5).
Los nuevos tipos de campos son:
search: se utiliza para crear cajas de bsqueda. Tiene un aspecto similar a un campo
de tipo texto. Adems podemos utilizar el atributo results=num para aadir un
histrico de bsquedas con num resultados. De momento no funciona ni en Firefox
ni en Chrome.
<label for="busqueda">Bsqueda con histrico: </label>
<input type="search" name="busqueda" id="busqueda" results="5"/>

number: campo numrico, incorpora dos botones para para incrementar o


decrementar el valor del campo. Adems podemos usar atributos para asignar
restricciones, como min=, max= o step=. El valor es almacenado en el
atributo value=.

range: campo numrico que permite seleccionar mediante una barra de


desplazamiento un valor entre dos valores predeterminados, especificados mediante
min= y max=. El valor actual es almacenado en el atributo value=. Adems
podemos indicar el incremento mnimo al desplazar la barra con step=.

color: permite seleccionar un color. De momento solo funciona en Opera 11.


tel: es un campo de texto normal pero valida si el valor introducido es un nmero
telefnico (todava no funciona).
url: valida direcciones web. De momento requiere http:// o http: simplemente. En

44

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

algunos navegadores cambia el aspecto del cambio.


email: valida direcciones de email. Funciona en algunos navegadores, mostrando
adems un aspecto diferenciado. Para iPhone adems adapta el teclado.
date: seleccionar un da en un calendario. En algunos navegadores (para mvil)
aparece un calendario desplegable (como en Opera).

month: selector para meses. En algunos navegadores (para mvil) aparece un


calendario desplegable.

week: selector para semanas. En algunos navegadores (para mvil) aparece un


calendario desplegable.

time: campo con formato para hora.

datetime: permite seleccionar fecha y hora.

datetime-local: permite seleccionar fechas y hora local.

output: este campo se utiliza para visualizar valores, por ejemplo el valor de un
campo range. De momento solo funciona en Opera. Se suele utilizar junto con la
propiedad onformchange para actualizar su valor:
<output onformchange="value = rango.value">0</output>

Adems, junto con estos nuevos tipos de campos, tambin se han incorporado nuevos
tipos de atributos. Estos nuevos atributos son aplicables a la mayora de los campos:
Autocomplete: La mayora de los navegadores incorporan la funcionalidad de
autocompletar algunos campos de los formularios con valores introducidos
anteriormente. Esta funcionalidad no siempre resulta til, sobre todo si alguien nos
roba nuestro porttil o dispositivo mvil. La nueva especificacin de HTML5 nos
permite desactivar el autocompletado en un formulario completo o solo en campos
especficos. El atributo autocomplete nos permite definir dos valores: on o off.
<form action="formaction.php" autocomplete="off">
...
</form>

El cdigo anterior desactivara el autocompletado de todo el formulario. Si por el


contrario solo queremos desactivar el autocompletado de un solo campo podemos
especificarlo as:
<input type="text" name="cuentadelbancosupersecreta" autocomplete="off" />

45

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Esta funcionalidad no se puede emular mediante cdigo JavaScript.


Placeholder: El atributo placeholder=texto se utiliza para colocar el valor de su
texto dentro del campo a modo de ayuda. Si se focaliza dicho campo, se elimina el
placeholder. Si abandonamos el campo sin aadir ningn valor, se vuelve a aadir el
placeholder. Esta funcionalidad siempre ha requerido del uso de JavaScript para ser
llevado a cabo, pero con la nueva especificacin este comportamiento puede definirse
de la forma:
<label for="referer">Nombre</label>
<input id="referer" name="referer" type="text"
placeholder="Escribe tu nombre completo" />

Obteniendo como resultado:

Required: Una de las tareas de validacin ms extendidas es la de los campos


requeridos. La nueva especificacin de HTML5 incluye el atributo required que nos
sirve para definir si un campo es requerido o no. Si un campo requerido est en blanco
el formulario no ser enviado y adems avisar con un mensaje:
<label for="username">Su nombre de usuario</label>
<input id="username" name="username" type="text" required/>

NOTA: Es un error grave de seguridad validar los formularios nicamente desde el


lado del cliente, es imprescindible adems realizar la validacin en el servidor.
Autofoco: El atributo de autofoco asigna el foco (cursor de escritura) al campo
indicado en cuando la pgina se ha cargado. Slo se puede asignar a un elemento de la
pgina. De momento este atributo solo lo soportan Safari, Chrome y Opera. Firefox e
IE, lo ignoran, pero se puede emular fcilmente mediante cdigo JavaScript (ver la
siguiente seccin Detectar funcionalidades de HTML5).
<input name="b" autofocus/>

List: Usando el atributo list con un elemento <input> podemos especificar una lista de
opciones. Esto permite al usuario seleccionar un valor de la lista o escribir uno que no
est en ella (este tipo de elemento se suele llamar Combo Boxes). Los elementos de la
lista se deben de indicar utilizando otro nuevo elemento de HTML5, el <datalist>. El
cual simplemente nos permite crear una lista de valores. En algunos navegadores estas
funcionalidades todava no funcionan, como en Chrome.
<label for="diasemana">Da de la semana:</label>
<input type="text" name="diasemana" id="diasemana" list="dias"/>
<datalist id="dias">
<option value="Lunes" />
<option value="Martes" />
<option value="Mircoles" />
<option value="Jueves" />
<option value="Viernes" />
<option value="Sbado" />
<option value="Domingo" />
</datalist>

46

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Con este cdigo obtendramos un resultado similar al de la siguiente imagen:

Pattern (formatting): Este atributo se utiliza para validar la entrada del usuario
mediante expresiones regulares. En la direccin
http://es.wikipedia.org/wiki/Expresi%C3%B3n_regular podemos obtener ms
informacin sobre las expresiones regulares. Ejemplo de uso (en Firefox y Chrome
funciona):
<label for="cp">Cdigo Postal</label>
<input id="cp" name="cp" pattern="[\d]{5}(-[\d]{4})" />

1.5.5. Mark
HTML5 tambin introduce un conjunto nuevo de elementos inline, solo que ya no se
llaman elementos inline sino text-level semantics o semntica a nivel de texto. Uno de
ellos es la etiqueta mark. Cuando realizamos una bsqueda en ciertos sitios, los elementos
encontrados en la pgina aparecen remarcados para facilitar su localizacin. Hasta ahora
el estilo se aplicaba con etiquetas <span>, pero esta solucin no es semntica. Es ah
donde entra en escena la nueva etiqueta <mark>:
<h1>Resultados de la bsqueda de la palabra anillo</h1>
<ol>
<li>El seor de los <mark>anillo</mark>s...</li>
<li>el cliente compr este <mark>anillo</mark></li>
</ol>

Si queremos podemos redefinir el estilo de esta nueva etiqueta de la misma forma que lo
hacamos con las etiquetas de HTML, por ejemplo, para cambiar el color de fondo a rojo:
mark { background-color: red; }

1.5.6. Canvas
El elemento canvas puede definirse como un entorno para crear imgenes dinmicas.
Utilizando su API en JavaScript podemos manipular el elemento canvas para dibujar en l
y crear grficos dinmicos de todo tipo (incluidas interfaces de aplicaciones web
completas). La API, aunque de momento est en desarrollo, la podemos encontrar en:
http://www.whatwg.org/specs/web-apps/current-work/multipage/the-canvas-element.html
Para empezar a usarlo lo nico que hay que especificar son sus dimensiones. El texto que

47

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

escribamos entre la apertura y cierre de la etiqueta canvas solamente ser interpretado por
navegadores que no soporten esta etiqueta:
<canvas id="myCanvas" width="360" height="240">
<p>Tu navegador no soporta canvas</p>
</canvas>

El resto de trabajo con canvas se ha de realizar con cdigo JavaScript. Primero debemos
referenciar este elemento y adquirir su contexto (que de momento solo est disponible
para 2D):
var canvas = document.getElementById(myCanvas);
var context = canvas.getContext(2d);

Una vez adquirimos el contexto podemos empezar a dibujar. La API bidimensional ofrece
muchas de las herramientas que podemos encontrar en cualquier aplicacin de diseo
grfico: trazos, rellenos, gradientes, sombras, formas y curvas Bzier. Los principales
mtodos disponibles son:
fillRect(x, y, width, height): dibuja un rectngulo relleno de color segn el estilo
activado.
strokeRect(x, y, width, height): dibuja solo el borde de un rectngulo, el interior ser
transparente.
clearRect(x, y, width, height): borra el rea indicada.
beginPath(): inicializa el dibujado de un trazo.
closePath(): cierra la figura creando una lnea desde el ltimo punto hasta el primero.
moveTo(x, y): mueve el puntero del trazo hasta las coordenadas indicadas (para poder
seguir dibujando).
lineTo(x, y): dibuja un trazo desde la posicin actual hasta las coordenadas indicadas.
stroke(): dibuja el trazo indicado desde el ltimo beginPath().
fill(): cierra el trazo definido desde el ltimo beginPath() y lo rellena.
arc(x, y, radius, startAngle, endAngle, anticlockwise): dibuja un arco con centro en
x, y y el radio definido. Los ngulos se definen en radianes (radianes =
(PI/180)*grados) y el ltimo parmetro es un valor booleano.
quadraticCurveTo(controlx, controly, x, y): dibuja una curva de bezier cuadrtica.
bezierCurveTo( control1x, control1y, control2x, control2y, x, y): dibuja una curva
de bezier cbica.
drawImage(x, y): dibuja una imagen (como objeto JavaScript) en el canvas.
createImageData(width, height): crea un objeto ImageData como un array de
pxeles para ser manipulado como un array de enteros.
getImageData(x, y, w, h): carga un objeto ImageData a partir del dibujo actual para
ser manipulado.
putImageData(imageData, x, y): mapea los valores de un objeto ImageData en el
dibujo actual.
strokeText(string, x, y): dibuja una cadena de texto usando solo su borde.
fillText(string, x, y): dibuja una cadena de texto.

48

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

A continuacin mostramos un ejemplo de dibujado en un objeto canvas una vez


capturado su contexto:
// Primero definimos las propiedades con las que vamos a dibujar
context.fillStyle
= #0000ff; // color de relleno azul
context.strokeStyle = #ff0000; // color de borde rojo
context.lineWidth
= 4;
// grosor de lnea
// Y a continuacin dibujar algunas figuras
context.fillRect (0,
0, 150, 50);
// rectngulo relleno
context.strokeRect(0, 60, 150, 50);
// rectngulo solo borde
context.clearRect (30, 25, 90, 60);
// borrar rea del canvas
context.strokeRect(30, 25, 90, 60);
// Orden de coordenadas: izqda,
arriba, ancho, largo

Obteniendo finalmente un resultado similar a:

Webs muy importantes estn cambiando sus contenidos a canvas y dejando de usar Flash,
como Slideshare (ver http://www.slideshare.net/AmitRanjan/slideshare-is-html5-now).
1.5.7. Audio
El nuevo elemento audio permite insertar archivos sonoros en diferentes formatos,
incluyendo mp3 y ogg. Adems provee de una interfaz de control sobre la reproduccin
del mismo con una API en JavaScript sin necesidad de plugins de ningn tipo (como
Flash). Aadir un reproductor de audio en HTML5 es muy simple:
<audio src="archivo.mp3" controls>
<p>Tu navegador no soporta el elemento audio</p>
</audio>

En Firefox obtendramos un resultado similar a:

El texto que se encuentra entre las etiquetas audio solo es tenido en cuenta por
navegadores que no soporten la nueva etiqueta. El atributo controls indica al navegador

49

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

que muestre los controles de reproduccin. En caso de no activarlo no se visualizara


nada, pero podramos controlar la reproduccin mediante funciones JavaScript, de la
forma:
<audio id="player" src="archivo.mp3"></audio>
<button
onclick="document.getElementById(player).play();">Reproducir</button>
<button
onclick="document.getElementById(player).pause();">Pausa</button>
<button onclick="document.getElementById(player).volume += 0.1;">Subir
Volumen</button>
<button onclick="document.getElementById(player).volume -= 0.1;">Bajar
Volumen</button>

Tambin podemos usar los atributos autoplay y loop para que se auto-reproduzca y
para que se cree un bucle de reproduccin infinito:
<audio src="archivo.mp3" autoplay loop></audio>

El formato de audio a utilizar vendr impuesto por el navegador usado y no por el


estndar:
Cdec

IE>=9

Firefox

Chrome

Safari

Opera

Ogg Vorbis

no

no

WAV PCM

no

MP3

no

AAC

no

Speex

no

no

no

no

Como puede verse, combinando Vorbis y MP3 podremos ofrecer audio a todos los
navegadores mayoritarios. Existe una forma de definir ms de un archivo de audio para la
etiqueta audio, en lugar de usar el atributo src, utilizaremos la etiqueta source para
poder definir mltiples archivos. Estas etiquetas se irn leyendo de arriba a abajo hasta
que el navegador encuentre un formato soportado. De esta manera podremos complacer
las necesidades de todos los usuarios sin discriminar a ningn navegador.
<audio controls>
<source src="archivo.ogg" type="audio/ogg" />
<source src="archivo.mp3" type="audio/mpeg" />
<object type="application/x-shockwave-flash"
data="player.swf?soundFile=archivo.mp3">
<param name="movie" value="player.swf?soundFile=archivo.mp3" />
<a href="archivo.mp3">Descarga el archivo de audio</a>
</object>
</audio>

En este ejemplo hemos aadido adems una tercera lnea con un reproductor Flash por si
no fuesen soportados ninguno de los formatos anteriores, y un link directo de descarga

50

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

para aquellos que tampoco soporten Flash. As estaremos ofreciendo nuestro contenido a
todos los navegadores y dispositivos manteniendo unas buenas prcticas en cuanto a
accesibilidad del contenido se refiere.
1.5.8. Vdeo
La nueva especificacin de HTML5 soporta la inclusin de vdeo empotrado en las
pginas web de forma nativa. El elemento video no especifica el formato del mismo sino
que el uso de uno u otro vendr impuesto por el fabricante del navegador:
Cdec

IE>=9

Firefox

Chrome

Safari

Opera

Ogg Theora

no

no

H.264

no

no

no

VP8

no

no

El elemento video dispone de los atributos autoplay, loop y preload, para activar la
auto-reproduccin, para indicar que se reproduzca en bucle y para activar/desactivar la
precarga del vdeo. Asimismo puedes utilizar los controles que te ofrece el navegador de
forma nativa utilizando el atributo controls o bien puedes ofrecer tus propios controles en
JavaScript. Dado que el vdeo ocupa un espacio, tambin podremos definir sus
dimensiones con los atributos width y height. E incluso podemos indicar una imagen
para que se muestre antes de la reproduccin mediante el atributo poster:
<video src="archivo.mp4" controls width="360" height="240"
poster="poster.jpg"> </video>

Con lo que obtendramos un resultado similar a:

Para dar soporte a todos los navegadores, podemos especificar diferentes archivos en
diferentes formatos. Adems podemos usar el mismo truco que usbamos con el elemento
audio para seguir dando soporte al plugin de Flash a travs de la etiqueta object, e incluso
incluir un link de descarga:

51

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<video controls width="360" height="240" poster="poster.jpg">


<source src="archivo.ogv" type="video/ogg" />
<source src="archivo.mp4" type="video/mp4" />
<object type="application/x-shockwave-flash" width="360" height="240"
data="player.swf?file=archivo.mp4">
<param name="movie" value="player.swf?file=archivo.mp4" />
<a href="archivo.mp4">Descarga la pelcula</a>
</object>
</video>

1.5.9. Geolocalizacin
La geolocalizacin es la forma de obtener tu posicin en el mundo y si quieres, compartir
esta informacin. Existen muchas maneras de descubrir donde te encuentras, por tu
direccin IP, la conexin de red inalmbrica, la torre de telefona mvil por la que se
conecta tu mvil, o usando directamente el posicionador GPS.
HTML5 incorpora una nueva funcionalidad para facilitar esta tarea, que depender de que
el navegador le de soporte. Est disponible a partir de las versiones de Opera 10.6,
Firefox 3.5, Chrome 5, Safari 5 e Internet Explorer 9.
if (navigator.geolocation)
{
navigator.geolocation.getCurrentPosition(showPosition);
}
function showPosition( position )
{
var lat = position.coords.latitude;
var lng = position.coords.longitude;
alert( "Latitud: " + lat + ", longitud: " + lng );
}

1.5.10. Almacenamiento Offline


El almacenamiento web est ampliamente soportado por los navegadores modernos, tanto
en plataforma escritorio como en plataforma mvil, Android 2.1+, iPhone 3.1+, iPad
4.2+, Opera Mobile 11.00+, Palm WebOS 1.4+ y BlackBerry 6.0+, Crome 4.0+, Firefox
3.5+, IE 8.0+, Opera 10.5+ y Safari 4.0+.
Tipos de almacenamiento
El almacenamiento web ofrece dos reas de almacenamiento diferentes, el
almacenamiento local (localStorage) y el almacenamiento por sesin (sessionStorage),
que difieren en alcance y tiempo de vida. Los datos alojados en un almacenamiento local
es solo accesible por dominio y persiste an cuando se cierre el navegador. El
almacenamiento por sesin es por ventana y su tiempo de vida est limitado a lo que dure
la ventana (o pestaa).
Los datos se almacenan de forma muy sencilla, por pares clave/valor, de la forma:

52

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

// Para almacenamiento persistente en local:


localStorage.setItem("miValor", valor);
// Para almacenamiento por sesin:
sessionStorage.setItem("miValor", valor);

Para recuperarlos posteriormente solo tenemos que hacer:


var miValor = localStorage.getItem("miValor");
var miValor = sessionStorage.getItem("miValor");

Las variables guardadas con sessionStorage slo se mantendran en caso de que


cambiemos de pgina o que el navegador se refresque, mientras que localStorage
guardara los datos aunque el navegador sea cerrado.
Tambin podemos borrar los valores almacenados, indicando un valor en concreto o
todos ellos:
localStorage.remove("miValor");
localStorage.clear();

Offline Application Cache (appCache)


Esta nueva caracterstica de HTML5 permite ejecutar aplicaciones Web aun cuando no
estamos conectados a Internet. Al visitar por primera vez una pgina web (que use
appCache) el navegador descarga y guarda todos los archivos necesarios para esa pgina.
La siguiente vez que la visitemos el navegador usar directamente los archivos
descargados (a no ser que estemos conectados y se compruebe que hay una versin ms
actual de la Web).
El principal componente del appCache es el archivo de manifiesto (manifest file), un
archivo de texto con la lista de archivos que el navegador cliente debe almacenar. En
primer lugar, para usar esta caracterstica debemos de indicar el archivo de manifiesto en
la etiqueta de apertura HTML:
<html manifest="app.manifest">

Este fichero debe de empezar con el texto CACHE MANIFEST. A continuacin en cada
nueva lnea indicaremos un recurso a almacenar (usando URLs absolutas o relativas),
adems podemos poner comentarios anteponiendo el smbolo #.
CACHE MANIFEST
# Esto es un comentario
index.html
js/scripts.js
css/estilos.css
imgs/logo.gif
imgs/image1.jpg

Una vez cargada la pgina, la nica peticin que realizar el navegador ser por el fichero

53

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

de manifiest. Aunque solo haya cambiado un letra del fichero, se descargarn todos los
recursos de nuevo. Para asegurarnos que servimos la ltima versin de nuestra pgina
cuando realizamos cambios, la forma ms sencilla y segura es actualizar el fichero de
manifiesto con un comentario indicando la fecha de la ltima actualizacin (o un nmero
de versin, etc.), de la forma:
CACHE MANIFEST
# Actualizado el 2011-10-12

Para ms informacin podis consultar las fuentes:


http://www.w3.org/TR/offline-webapps/
http://www.w3.org/TR/html5/offline.html
1.5.11. Detectar funcionalidades de HTML5
Modernizr es una librera de JavaScript con licencia MIT de cdigo abierto que detecta si
son compatibles elementos de HTML5 y CSS3. Podemos descargar la librera desde
http://www.modernizr.com/. Para utilizarla solo hay que incluir en el <head> de tu
pgina de la forma:
<head>
<script src="modernizr.min.js"></script>
</head>

Modernizr se ejecuta automticamente, no es necesario llamar a ninguna funcin. Cuando


se ejecuta, se crea una objeto global llamado Modernizr, que contiene un set de
propiedades Boleanas para cada elemento que detecta. Por ejemplo si su navegador
soporta elementos canvas, la propiedad de la librera Modernizr.canvas ser true. Si
tu navegador no soporta los elementos canvas, la propiedad ser false, de la forma:
if (Modernizr.canvas) {
// s que hay soporte
} else {
// no hay soporte para canvas
}

Para comprobar elementos de un formulario tambin podemos crearnos dos simples


funciones que validan el soporte para diferentes tipos de inputs y atributos:
Comprobar si un input es soportado
Con la siguiente funcin podemos comprobar si un navegador soporta o no los nuevos
tipos de inputs:
function inputSupports(tipo) {
var input = document.createElement(input);
input.setAttribute(type, tipo);
if (input.type == text) {

54

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

return false;
} else {
return true;
}
}

Por lo que podemos usarlo de la siguiente forma:


if (!inputSupports(range)) {
// Input tipo range no soportado
}

Comprobar si un atributo es soportado


Para comprobar si hay soporte para un atributo
function attrSupports(el, attr) {
var telement = document.createElement(el);
if (attr in telement) {
return true;
} else {
return false;
}
}

Por lo que podemos usarlo para comprobar, por ejemplo, los atributos autofocus,
placeholder o required:
if (!attrSupports(input, autofocus)) {
document.getElementById(search_string).focus();
}
if (!attrSupports(input, placeholder)) {
// Atributo placeholder no soportado
}
if (!attrSupports(input, required)) {
// Atributo required no soportado
}

1.6. CSS3
La especificacin de CSS3 viene con interesantes novedades que permitirn hacer webs
ms elaboradas y ms dinmicas, con mayor separacin entre estilos y contenidos. Dar
soporte a muchas necesidades de las webs actuales, sin tener que recurrir a trucos de
diseadores o lenguajes de programacin.

Aunque CSS3 est todava en fase de desarrollo, la mayora de navegadores ya dan

55

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

soporte a casi todos los nuevos estilos, como Firefox, Chrome o Safari. Por el contrario
Internet Explorer no ha empezado a incorporar estos nuevos elementos hasta la versin 9.
Las principales propiedades nuevas en CSS3 son:
Selectores de atributos y propiedades
Nuevas pseudo-clases
Formatos de color: colores HSL, colores HSLA, colores RGBA, Opacidad
Bordes: border-color, border-image, border-radius, box-shadow
Fondos: background-origin, background-clip, background-size, capas con mltiples
imgenes de fondo
Texto: text-shadow, text-overflow, rotura de palabras largas, Web Fonts, creacin de
mltiples columnas de texto
Modelo de caja bsico: overflow
Transiciones y transformaciones
A continuacin veremos con ms detalle cada una de estas nuevas propiedades.
1.6.1. Nuevos selectores de atributos
En primer lugar encontramos 3 nuevos selectores de atributos:
elemento[atributo^="valor"]: Selecciona los elementos con ese atributo y que su
valor comienza por la cadena de texto indicada en "valor".
elemento[atributo$="valor"]: Selecciona los elementos con ese atributo y que su
valor termina por la cadena de texto indicada en "valor".
elemento[atributo*="valor"]: Selecciona los elementos con ese atributo y que su
valor contiene la cadena de texto indicada en "valor".
Por ejemplo:
// Selecciona todos los enlaces que apunten a una direccin de correo:
a[href^="mailto:"]{...}
// Selecciona todos los enlaces que apuntan a pginas .php
a[href$=".php"]{...}
// Selecciona todos los enlaces que lleven a una pgina que contenga la
palabra ejemplo:
a[href*="ejemplo"]{...}

Tambin incorpora nuevas formas de seleccionar etiquetas adyacentes:


h1 + h2{...}: Etiquetas inmediatamente adyacentes.
h1 ~ h2{...}: Selector general de hermanos. Vlido cuando <h2> se encuentre despus
de <h1>, pero puede haber otras etiquetas de por medio.
Ejemplo:
<h1>Ttulo</h1>
<h2>Subttulo adyacente</h2>

56

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<h1>Ttulo</h1>
<p> prrafo de separacin</p>
<h2>Subttulo con selector general de hermanos</h2>

Tambin podemos indicar atributos especficos de una etiqueta, con:


etiqueta1[atributo1=valor1]: seleccionara todas las etiquetas etiqueta1 que
contengan un atributo llamado atributo1 cuyo valor sea igual a valor1. Por
ejemplo, si queremos indicar un estilo para todas las etiquetas input que sean de tipo
texto:
input[type="text"] {
background: #eee;
}

1.6.2. Nuevas pseudo-clases


Una pseudo-clase es un estado o uso predefinido de un elemento al que se le puede
aplicar un estilo independientemente del estilo aplicado al de su estado por defecto. En
CSS3 se han aadido muchas nuevas pseudo-clases para facilitar a los programadores el
uso de algunos estilos avanzados en el diseo de pginas Web. Las nuevas pseudo-clases
son:
:nth-child(n) - Fija el aspecto de una ocurrencia especfica del elemento nodo hijo
especificado. Por ejemplo, el tercer elemento nodo hijo de una lista sera
li:nth-child(3). Adems se pueden usar pequeas expresiones como parmetro para
por ejemplo seleccionar todos los elementos impares: nth-child(2n+1) los pares
nth-child(2n), etc. Los elementos impares y pares tambin se pueden seleccionar
usando nth-child(odd) y nth-child(even)
:nth-last-child(n) - igual que :nth-child(n) pero empezando a contar desde el final.
:nth-of-type(n) - Fija la apariencia de una ocurrencia especfica del elemento con el
tipo de selector especificado en un elemento padre. Por ejemplo la segunda lista no
ordenada sera ul:nth-of-type(2). Tambin permite los mismos parmetros que
:nth-child(#).
:nth-last-of-type(n) - igual que :nth-of-type(n) pero empezando a contar desde el
final.
:first-child - Fija el aspecto del primer elemento de un tipo de selector solo si es el
primer nodo hijo de su elemento padre, por ejemplo la primera etiqueta <li> de una
lista <ol>.
:last-child - Ultimo elemento de una lista de elementos de un tipo dado.
:first-of-type - Selecciona el primer elemento de un tipo concreto dentro de la lista de
hijos.
:last-of-type - Selecciona el ltimo elemento de un tipo.
:only-child - Selecciona el elemento si es el nico elemento hijo.
:only-of-type - Selecciona el elemento si es el nico elemento hijo de ese tipo.
:empty - Selecciona los elementos que no tienen hijos (incluyendo nodos de texto).
:enabled - Selecciona los elementos de la interfaz que tengan el estado enable.

57

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

:disabled - Selecciona los elementos de la interfaz que tengan un estado disabled.


:not(s) - Selecciona los elementos que no coincidan con el selector especificado.
:lang(language) - nos permite especificar estilos que dependen del idioma
especificado por la propiedad language (en, sp, etc.)

Ejemplos de uso:
tr:nth-child(even) {
background: silver;
}
tr:nth-child(odd) {
background: white;
}
p:lang(en) {
color: gray;
font-style: italic;
}

Formularios
Adems tambin se han aadido nuevas pseudo-clases que podemos usar en los
formularios para aplicar un formato segn el estado de un campo. Estas propiedades van
en concordancia con los nuevos campos introducidos en HTML5 (ver la seccin de
formularios de HTML5). estas son:
:valid - campo vlido (depender del tipo de campo).
:invalid - campo invlido (depender del tipo de campo).
:required - campo requerido (marcado con el atributo required).
:optional - campo opcional (campo no marcado con el atributo required).
:checked - elemento marcado (o checked, vlido para radio button o checkbox).
:in-range - valor dentro del rango indicado (para campos numricos o de rango).
:out-of-range - valor fuera de rango (para campos numricos o de rango).
:read-only - campo de solo lectura.
:read-write - campo de lectura / escritura.
Algunos ejemplos de uso:
<head>
<style>
#form1 input:valid { background:lightgreen; }
#form1 input:invalid { border-color:red; }
#form1 specialInput input:valid { background:green; }
</style>
</head>
<body>
<form id="form1" name="form1" method="post" action="formaction.php">
<p>Nombre:
<input type="text" name="nombre" id="nombre" required/>
<p/>
<p>Usuario:
<specialInput>
<input type="text" name="usuario" id="usuario" required/>
</specialInput>
<p/>

58

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

</form>
</body>

En este ejemplo cabe destacar la etiqueta specialInput, que no es ninguna etiqueta


existente, sino una nueva etiqueta que hemos creado para aplicar un formato especial.
Adems podemos aplicar estas pseudo-clases en cadena y hacer cosas como:
input:focus:required:invalid {
background: pink url(ico_validation.png) 379px 3px no-repeat;
}
input:required:valid {
background-color: #fff; background-position: 379px -61px;
}

Dado que Internet Explorer 6-8 no soporta la mayora de pseudo-clases se han


desarrollado algunas libreras de JavaScript que realizan las mismas funciones para estos
navegadores, como select[ivizr] que podris descargar de su pgina oficial
http://selectivizr.com/.
1.6.3. Color
En CSS3 se han incorporado nuevas formas para definir los colores:
rgba( red, green, blue, opacity ); - Color RGBA. El valor de opacidad debe de estar
entre 0 y 1, siendo 0 totalmente transparente. Por ejemplo, podemos usarlo de la
forma:
background-color: rgba(255, 115, 135, 0.5);
color: rgba(255, 115, 135, 0.5);

hsl( hue, saturation, lightness ); - Modelo de color HSL.


hsla(hue, saturation, lightness, alpha); - Modelo de color HSLA.
cmyk(cyan, magenta, yellow, black); - Modelo de color CMYK.
opacity: 0.5; - Tambin podemos indicar el valor de transparencia u opacidad por
separado, debiendo de estar este valor entre 0 y 1, siendo 0 totalmente transparente y
1 totalmente opaco. Para dar tambin soporte a Internet Explorer usaremos:
filter:alpha(opacity=50);.

1.6.4. Bordes
En CSS3 se han incorporado cuatro nuevas propiedades para dar formato a los bordes de
una caja. Estas propiedades no estn todava plenamente soportadas en todos los
navegadores, por lo que para que funcione en la mayora de ellos tendremos que usar
tambin las propiedades nativas del navegador (simplemente aadiremos los prefijos
-webkit- y -moz-). Las nuevas propiedades son:
border-radius: permite crear cajas con esquinas redondeadas. Hasta ahora esto solo
se poda hacer insertando imgenes que simularan esta caracterstica. Ahora lo

59

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

podemos hacer de una forma mucho ms sencilla:


-webkit-border-radius: 30px;
-moz-border-radius: 30px;
border-radius: 30px;

Adems tambin podemos indicar cada uno de los bordes por separado:
-moz-border-radius-topleft: 10px;
-moz-border-radius-topright: 20px;
-moz-border-radius-bottomright: 30px;
-moz-border-radius-bottomleft: 40px;
-webkit-border-radius: 10px 20px 30px 40px;
border-radius: 10px 20px 30px 40px;

border-image: este nuevo estilo nos permite usar una imagen como borde de una
caja. Tenemos que indicar tres atributos: la imagen a utilizar, el grosor y la forma de
aplicar la imagen (stretch, repeat, round, none). Ejemplo de uso:
-webkit-border-image: url(imagen.png) 27 repeat;
-moz-border-image: url(imagen.png) 27 repeat;
border-image: url(imagen.png) 27 repeat;

El resultado depender de la imagen que utilicemos para el borde, pero por ejemplo
podramos obtener resultados como el siguiente:

border-color: Permite crear degradados en los bordes de una caja indicando la


secuencia de colores del degradado (pxel a pxel y de dentro hacia fuera), de la
forma:
-webkit-border-bottom-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-webkit-border-top-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-webkit-border-left-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-webkit-border-right-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-moz-border-bottom-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-moz-border-top-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-moz-border-left-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
-moz-border-right-colors:#555 #666 #777 #888 #999 #aaa #bbb #ccc;
border: 8px solid #000;

Con lo que obtendramos un resultado similar a:

box-shadow: Permite dar sombra a elementos de bloque. Tiene 4 atributos: la


distancia horizontal de la sombra, la distancia vertical de la sombra, el desenfoque
(blur) y el color de la sombra. Adems podemos usar valores negativos para las
distancias horizontal y vertical para crear sombras en otros sentidos. Un ejemplo de
sombra en color gris:
-moz-box-shadow:3px 3px 6px #888888;
-webkit-box-shadow:3px 3px 6px #888888;
box-shadow:3px 3px 6px #888888;

60

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Con lo que obtendramos un resultado similar a:

1.6.5. Fondos
CSS3 tambin ha introducido nuevas propiedades para definir el estilo de las imgenes de
fondo:
background-origin: border-box | padding-box | content-box - permite definir el
origen de coordenadas sobre el que se va a colocar la imagen de fondo. Acepta tres
posible valores: border-box para que el fondo empiece desde el mismo borde del
elemento, padding-box para que la imagen de fondo se coloque a partir del
espaciado de padding, y por ltimo content-box para que la imagen de fondo se
coloque donde empieza el contenido del elemento, sin tener en cuenta el borde ni el
padding.
background-clip: border-box | padding-box | content-box - define el rea sobre la
que se extiende la imagen de fondo, puede tomar tres valores: border-box se
extiende por toda el rea dentro de la zona definida a partir del borde, padding-box
se extiende a partir del espaciado de padding y content-box el fondo se extiende
solo dentro del rea de contenido.
background-size: Permite indicar el tamao de la imagen de fondo. Acepta diferentes
atributos:
background-size: 200px; // especifica ancho y alto a la vez
background-size: 200px 100px; // 200px de ancho y 100px de alto
background-size: auto 200px; // ajustar la anchura automticamente
background-size: 50% 25%; // Tambin podemos indicar el tamao con
porcentajes
background-size: contain; // Escalar la imagen al tamao mximo posible
(conservando las proporciones originales) para que quepa dentro del rea
asignada.
background-size: cover; // Escalar la imagen para que cubra completamente el
rea asignada (conservando las proporciones originales).

Capas con mltiples imgenes de fondo: Con la propiedad background ahora


podemos indicar varias imgenes de fondo, simplemente separndolas con comas.
Para cada propiedad background debemos definir cuatro valores: imagen de fondo,
posicin vertical, posicin horizontal, modo de repeticin (repeat, repeat-x, repeat-y,
no-repeat). Ejemplo:
background: url(imagen1.png) 10px center no-repeat,
url(imagen2.png) 0 center repeat-x;

Dado que estas propiedades no son soportadas todava en todos los navegadores,
deberemos de definirlas tambin aadiendo los prefijos -webkit- y -moz- para dar un

61

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

mayor soporte.
1.6.6. Texto
Las nuevas propiedades de CSS3 para dar formato a textos son:
text-shadow: Permite dar sombra a un texto. Sus propiedades son distancia
horizontal, distancia vertical, desenfoque (blur) y color de la sombra. Por ejemplo:
text-shadow: 2px 2px 2px #9e9e9e;
filter: dropshadow(color=#9e9e9e, offx=2, offy=2);

Con lo que obtendramos un resultado similar a:

word-wrap: break-word; - Permite separar palabras muy largas dentro de un


elemento de bloque. Por defecto toma el valor normal, por lo que las palabras largas
se saldran del borde del elemento. Con el valor break-word indicamos que las
palabras pueden ser partidas para que quepan en el ancho de la caja, de la forma:

text-overflow: clip | ellipsis; - Indica la forma de partir texto cuando excede el


tamao de su contenedor. Con clip el texto sobrante ser cortado directamente
aunque se quede una palabra por la mitad, mientras que ellipsis quitar la ltima
palabra que no quepa y pondr en su lugar unos puntos suspensivos. Esta propiedad
de momento no funciona en Firefox.
font-face: Permite utilizar tipografas diferentes a las estndar, que sern importadas
desde un fichero indicado. De momento soporta los formatos: .eot, .ttf y .otf. Para
importar una fuente hay que seguir la siguiente sintaxis:

@font-face{
font-family:<nombre_fuente>;
src: <source>;
[font-weight:<weigth>];
[font-style:<style>];
}

Con font-family indicamos el nombre que le damos a la fuente, y src nos permite
seleccionar el fichero a cargar. Los otros dos parmetros son opcionales y tendrn
valor normal por defecto. Por ejemplo:
@font-face {
font-family: LeagueGothic;
src: url(LeagueGothic.otf);
}
// Ahora ya podemos usar esta fuente:
p {

62

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

font-family: LeagueGothic;
}

1.6.7. Columnas
Se han aadido nuevas propiedades que nos permiten crear columnas directamente a
partir de un texto, estas son:
column-count: Define el nmero de columnas en el que se va a dividir el texto. El
texto ser dividido de la mejor forma posible para que ocupe todo el espacio.
column-width: Define el ancho de la columna (en unidades CSS).
column-gap: Define el espacio entre las columnas (en unidades CSS).
column-rule: Mediante esta propiedad podemos aadir una lnea separadora entre las
columnas, si no especificamos esta propiedad no se aadir ninguna lnea. Debemos
de indicarle tres valores: ancho de la lnea (en unidades CSS), estilo de la lnea (solid,
dotted, double, etc.) y color de la lnea.
Para dar un mayor soporte antepondremos los prefijos -webkit- y -moz-, de la forma:
-webkit-column-count: 3;
-webkit-column-rule: 1px solid silver;
-webkit-column-gap: 10px;
-moz-column-count: 3;
-moz-column-rule: 1px solid silver;
-moz-column-gap: 10px;
column-count: 3;
column-rule: 1px solid silver;
column-gap: 10px;

Con lo que obtendramos un resultado similar a:

1.6.8. Modelo de caja bsico


Se han aadido nuevas propiedades para la disposicin de elementos dentro de una caja:
overflow: visible | hidden | scroll | auto; - permite indicar que ocurrir si el
contenido excede el rea de un elemento, acepta cuatro posibles valores:
visible: No se recorta el contenido, la parte que quede fuera ser visible. Es el
valor por defecto.
hidden: El contenido que sobresalga ser ocultado y tampoco se mostrar la barra
de scroll.

63

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

scroll: El contenido se recorta y el navegador muestra la barra de scroll para ver el


resto del contenido.
auto: Si el contenido se recorta el navegador mostrar una barra para ver el resto
del contenido.

overflow-x: igual que overflow pero indicaremos solo la propiedad en horizontal.


overflow-y: igual que overflow pero solo para vertical.
resize: none | horizontal | vertical | both; - habilita la posibilidad de redimensionar
manualmente una caja. Puede tomar los valores: none, horizontal (permitir
redimensionar solo en horizontal), vertical (solo en vertical), o both (redimensionar
ambas dimensiones). Se recomienda adems aadir la propiedad overflow: hidden
para ocultar los elementos al redimensionar. Por ejemplo:
resize:both;
overflow:auto;

1.6.9. Transiciones
Una de las propiedades ms novedosas que incorpora CSS3 es la posibilidad de crear
animaciones mediante transiciones y transformaciones. Se pueden aplicar transiciones a
la mayora de propiedades (posiciones, fondo, color, tamao, etc.). Desafortunadamente,
no todos los navegadores usan los nombres estndares, por lo que tendremos que aadir
los prefijos -webkit-, -moz- y -o- para dar un mayor soporte. La buena noticia es
que la sintaxis para los valores en todos ellos es consistente:
transition-property: propertyName; - Indica la propiedad sobre la que se aplicar la
transicin. Se puede aplicar sobre casi todas las propiedades: background, color,
height, width, border, etc. Adems tambin podemos usar el valor all para que se
aplique sobre todas las propiedades disponibles, por ejemplo:
-webkit-transition-property: all;
-moz-transition-property: all;
-o-transition-property: all;
transition-property: all;

transition-duration: duration; - Indica el tiempo que debe durar la transicin en


segundos (0.5s) o en milisegundos (500ms):
-webkit-transition-duration: 1s;
-moz-transition-duration: 1s;
-o-transition-duration: 1s;
transition-duration: 1s;

transition-timing-function: timingFunction; - Es la funcin de tiempo que seguir


la transicin, indica los cambios de velocidad a lo largo de la animacin. Puede tomar
cinco valores diferentes: ease (valor por defecto), linear, ease-in, ease-out, ease-in-out
y cubic-bezier(cp1x, cp1y, cp2x, cp2y). Por ejemplo:
-webkit-transition-timing-function: linear;
-moz-transition-timing-function: linear;

64

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

-o-transition-timing-function: linear;
transition-timing-function: linear;

transition-delay: delay; - Permite establecer un retraso inicial antes de ejecutar la


transicin. El tiempo de retraso se debe de indicar en segundos (0.5s) o en
milisegundos (500ms):
-webkit-transition-delay: 0.2s;
-moz-transition-delay: 0.2s;
-o-transition-delay: 0.2s;
transition-delay: 0.2s;

transition: propertyName duration timingFunction delay; - Tambin podemos


indicar las cuatro propiedades explicadas en una sola lnea:
-webkit-transition: all 1s linear 0.2s;
-moz-transition: all 1s linear 0.2s;
-o-transition: all 1s linear 0.2s;
transition: all 1s linear 0.2s;

En general, lo mejor es declarar la transicin en la propiedad base, sin pseudo-clases. De


esta forma conseguiremos que se ejecute en ambas direcciones, por ejemplo:
.btn1 {
background: #9c3;
-webkit-transition: background 0.3s ease;
-moz-transition: background 0.3s ease;
-o-transition: background 0.3s ease;
transition: background 0.3s ease;
}
.btn1:hover {
background: #690;
}

1.6.10. Transformaciones
La propiedad transform nos permite aplicar transformaciones 2D o 3D a un elemento.
Por ejemplo nos permite rotar, escalar, mover, etc. el elemento indicado. Esta propiedad
todava no es soportada por todos los navegadores, por lo que tendremos que aadir los
prefijos -ms-, webkit-, -moz- y -o- para dar un mayor soporte. Algunas de las
funciones de transformacin que podemos utilizar son:
none: Indica que no se tiene que aplicar ninguna transformacin.
translate(x,y): Define una traslacin 2D.
translateX(x): Traslacin en la coordenada X.
translateY(y): Traslacin en la coordenada Y.
scale(x,y): Define una transformacin de escalado 2D, deberemos de indicar valores
entre 0.1 y 2.
scaleX(x): Escalado en la coordenada X, deberemos de indicar valores entre 0.1 y 2.
scaleY(y): Escalado en la coordenada Y, deberemos de indicar valores entre 0.1 y 2.
rotate(angle): Aplica una rotacin, el ngulo debe ser indicado en grados (ejem:

65

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

30deg).
skew(x-angle,y-angle): Define una transformacin 2D de sesgo (o torsin), indicada
en grados (deg).
skewX(angle): Define una transformacin de sesgo sobre la coordenada X (indicada
en grados).
skewY(angle): Define una transformacin de sesgo sobre la coordenada Y (indicada
en grados).

Adems tambin podemos indicar varias transformaciones en una misma lnea, de la


forma:
#myDIV {
-moz-transform: scale(1.2) rotate(9deg) translate(5px, 2px) skew(5deg,
5deg);
-webkit-transform: scale(1.2) rotate(9deg) translate(5px, 2px)
skew(5deg, 5deg);
-o-transform: scale(1.2) rotate(9deg) translate(5px, 2px) skew(5deg,
5deg);
-ms-transform: scale(1.2) rotate(9deg) translate(5px, 2px) skew(5deg,
5deg);
transform: scale(1.2) rotate(9deg) translate(5px, 2px) skew(5deg,
5deg);
}

Hay muchos ms tipos de transformaciones, aunque algunas de ellos no son funcionales


todava (sobre todo las funciones 3D), para ms informacin consulta:
http://www.w3schools.com/cssref/css3_pr_transform.asp.

1.7. Ms informacin
Para obtener una referencia mucho ms completa sobre las hojas de estilo podemos
consultar alguna de las siguientes Webs:
Referencia detallada de todos los estilos:
http://www.w3schools.com/cssref/default.asp
Especificaciones: http://www.w3.org/Style/CSS/
Tutoriales: http://www.desarrolloweb.com/manuales/manual-css-hojas-de-estilo.html
Sobre CSS3 podemos obtener ms informacin en:
http://www.w3schools.com/css3/default.asp
http://www.w3.org/TR/2001/WD-css3-roadmap-20010523/
Adems, existen algunas pginas Web que proporcionan generadores de estilos CSS
que nos pueden ayudar, como:
http://css3generator.com/
http://www.colorzilla.com/gradient-editor/

66

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

2. Ejercicios - Introduccin al desarrollo web para mviles


En esta primera sesin vamos a realizar algunos ejercicios para practicar con las distintas
versiones de HTML, HTML5, CSS y CSS3. Descarga la plantilla para los ejercicios
desde sesion01-ejercicios.zip. Al descomprimirlo aparecer un archivo por cada ejercicio.

2.1. Ejercicio 1 - Estructura en HTML (0.6 puntos)


En este primer ejercicio vamos a hacer una pequea Web de ejemplo utilizando las
etiquetas DIV para estructurar el contenido. Nuestra Web va estar dividida en cuatro
apartados, cada uno tendr un identificador nico: header, nav, content, footer.
En la parte superior vamos a crear un campo DIV con identificador "header", en el que
incluiremos el logo del curso (logo.jpg, con un alto de 50px) y el texto "DADM" (color
blanco con tamao de 16 puntos).
A continuacin incluiremos la barra de navegacin, otro campo DIV con identificador
"nav". Dentro de este a su vez crearemos 3 cajas tipo DIV de la clase "navElement". Las
cajas tendrn los textos "Inicio", "Contenidos" y "Profesorado". Como estilo indicaremos
que la clase "navElement" tenga el color de fondo "#f0f0f0" y que cambie al color
"#005682" cuando el ratn pase por encima.
La seccin central la crearemos tambin mediante una etiqueta DIV con el identificador
"content". Esta seccin contendr una lista no ordenada (del tipo UL), el contenido de
esta lista lo podemos obtener del fichero con la plantilla para este ejercicio.
El pie de pgina lo crearemos tambin utilizando una etiqueta DIV con el identificador
"footer" y el texto "Dept. Ciencia de la Computacin e IA". Como estilo le aplicaremos el
color de texto gris.
Ahora tenemos que terminar de ajustar los estilos CSS para que la pgina se vea
correctamente. Para los elementos "header", "nav", "content" y "footer" definiremos un
ancho del 100% e indicaremos que no se permiten elementos por su lado izquierdo (es
decir, que deben de estar en una nueva lnea, esto lo haremos mediante clear:left;).
Para el estilo "navElement" indicaremos que se tiene que situar a continuacin del
anterior (en la misma lnea, esto lo haremos mediante float: left;).

2.2. Ejercicio 2 - Terminando la Web de ejemplo (0.6 puntos)


En este ejercicio vamos a terminar la web del ejercicio 1, aadindole el contenido de los
enlaces que faltan. En primer lugar copiamos el fichero resultado del ejercicio anterior y
lo renombramos a "sesion01-ejercicio2.html". En este fichero vamos a modificar las
opciones de men para aadir enlaces a Inicio (un enlace a este mismo fichero),
Contenidos (enlace a "sesion01-ejercicio2_contenidos.html") y Profesorado (enlace a

67

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

"sesion01-ejercicio2_profesorado.html").
Al aadir estos enlaces se modificar su apariencia, por lo que tendremos que modificar
la hoja de estilo. Aadimos dos nuevos estilos ".navElement a" para indicar que el color
de los enlaces es negro y que no se dibuje la lnea de subrayado del enlace
(text-decoration: none;). Y otro estilo ".navElement a:hover" para que el enlace
cambie a color blanco cuando el ratn pase por encima.
El siguiente paso es pasar todos estos estilos a un fichero independiente, llamado
"sesion01-ejercicio2_css.css". Simplemente tendremos que crear este fichero y cortar y
pegar en l todos los estilos que ya tenemos creados. En el fichero principal HTML
tendremos que cargar esta hoja de estilo, quedando solo una lnea (<link
href="sesion01-ejercicio2_css.css" rel="stylesheet" type="text/css" />).
Ahora vamos a crear los dos ficheros HTML que faltan. Para esto realizamos dos copias
del
fichero
HTML
principal
y
las
renombraremos
a
"sesion01-ejercicio2_contenidos.html" y "sesion01-ejercicio2_profesorado.html". En
cada una de estas copias solo tendremos que cambiar el contenido de la zona central. Para
el fichero de contenidos buscaremos el ndice general de contenidos del curso y lo
aadiremos en una lista no numerada (UL). Y para el fichero de profesorado aadiremos
tambin en una lista no numerada los nombres de los profesores.
Por ltimo vamos a hacer que al cambiar de seccin se quede marcado el enlace
correspondiente. Esto lo haremos aadiendo el estilo "visited" a la clase del enlace actual
visitado, por lo que este enlace tendr dos estilos. Para aadir ms de un clase a un
elemento HTML lo podemos hacer separando las clases con espacios, de la forma: <div
class="navElement visited">. Finalmente definimos el estilo "visited" en la hoja de
estilo con el color de fondo "#005682".

2.3. Ejercicio 3 - Estructura de HTML 5 (0.6 puntos)


En este ejercicio vamos a modificar la web que hemos hecho en el ejercicio anterior para
aplicarle las nuevas etiquetas semnticas de HTML5. Para esto seguiremos los siguientes
pasos:
1. Copiamos los ficheros del ejercicio anterior y los renombramos por
"sesion01-ejercicio3".
2. Cambiamos la direccin de los enlaces y la inclusin del fichero CSS en la cabecera
para que apunten correctamente a los nuevos ficheros.
3. En cada uno de los ficheros HTML cambiamos las etiquetas DIV principales (con
identificadores header, nav, content, footer) y las sustituimos por las etiquetas
semnticas de HTML5.
4. Modificamos el fichero CSS para aplicar los estilos sobre las nuevas etiquetas
semnticas de HTML5 (simplemente tendremos que cambiar los identificadores por
los nombres de estas etiquetas, por ejemplo: "#header" por "header").

68

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

2.4. Ejercicio 4 - Canvas (0.2 puntos)


Para practicar con el elemento Canvas vamos a dibujar unas sencillas figuras geomtricas.
En primer lugar, en el cuerpo del documento, tenemos que crear el canvas con
identificador "myCanvas" y dimensiones de 360x240.
En el cdigo JavaScript obtendremos la instancia del canvas a partir de su identificador
"myCanvas" y adquiriremos su contexto 2D. Definiremos un estilo de relleno con color
'#0000ff', un color de borde '#ff0000' y un grosor de lnea de 4 pxeles.
Dibujamos un rectngulo relleno en las coordenadas (0, 0, 150, 50), y otro rectngulo
usando solo el borde en las coordenadas (0, 60, 150, 50). Por ltimo dibujaremos un
tringulo usando la herramienta trazo (path). Iniciamos el trazo (beginPath), definimos el
primer punto en (160, 0) y los siguientes puntos en (270, 0), (160, 110) y (160, 0). Por
ltimo indicamos que rellene la figura y que cierre el trazo.

2.5. Ejercicio 5 - Geolocalizacin (0.2 puntos)


En este ejercicio solo tenemos que aadir una lnea, y es el comando necesario para
obtener la posicin actual, al cual le pasaremos como parmetro el nombre de la funcin
"showPosition". Esta funcin ser la encargada de mostrar nuestras coordenadas
(utilizando la API de Google Maps).

2.6. Ejercicio 6 - Almacenamiento Offline (0.3 puntos)


Para practicar con la nueva funcionalidad de almacenamiento Offline vamos a hacer un
pequeo ejemplo que guarde de forma automtica una nota. Si abrimos la plantilla
correspondiente solo tenemos que definir las funciones de cargar, guardar y borrar la
nota. Para esto utilizaremos el almacenamiento en local (localStorage) y el identificador
'savedNote', y para el borrado eliminaremos todo el contenido directamente (clear).
Adems en la seccin de estilo CSS indicaremos para el "contenedor-nota" que utilice la
imagen de fondo "imgs/stickynote.jpg".

2.7. Ejercicio 7 - CSS3 (0.5 puntos)


En este ejercicio vamos a probar algunas de las funcionalidades nuevas de CSS3. Para
todos los ejemplos recuerda indicar los nombres de las propiedades usando tambin los
nombres nativos de los navegadores con los prefijos -webkit-, -moz- y -o-.
En el primer ejemplo "borderRadius" vamos a indicar que el cuadro tenga bordes
redondeados con un radio de 30 pxeles.
En el segundo ejemplo (borderShadow) crearemos una sombra para el borde, con los
siguientes atributos: distancia horizontal de la sombra de 5px, distancia vertical de la

69

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

sombra 5px, desenfoque de 6px y color de la sombra grisceo (#888888).


En el tercer ejemplo (textShadow) vamos a crear una sombra para el texto de 2px para sus
distancias horizontal y vertical, de 2 pxeles para el desenfoque y "#9e9e9e" como color
de sombra.
En el cuarto ejemplo (multiColumn) vamos a probar la funcionalidad de columnas. Aqu
solo tendremos que indicar que el nmero de columnas es de 2 y que el espacio entre las
columnas es de 15px.
En el ltimo ejemplo (boxTransition) vamos a crear un efecto de transicin. Usando la
propiedad "transition" (para establecer todos los valores en una sola lnea), indicaremos
que vamos a realizar la transicin sobre "margin-left", con una duracin de 3s, y usando
la funcin de tiempo "ease-in-out".

70

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

3. Introduccin a Sencha Touch


3.1. Introduccin
Sencha Touch es un framework para el desarrollo de aplicaciones mviles centrado en
WebKit (base de los navegadores web Safari, Google Chrome, Epiphany, Maxthon, y
Midori entre otros). Fue el primer framework basado en HTML5 y JavaScript, adems
utiliza CSS3 para realizar animaciones. La apariencia de las aplicaciones desarrolladas es
similar al de las aplicaciones nativas en Android, BlackBerry e iOS. Sencha Touch est
disponible tanto en versin con licencia comercial como con licencia Open Source GPL
v3.

Una de las principales ventajas de Sencha Touch es la cantidad de controles IU o


elementos de interfaz que incluye, todos ellos muy fciles de usar y personalizar. Ha sido
diseado especficamente para dispositivos tctiles por lo que incluye una amplia gama de
eventos tctiles o gestures, que comnmente son usados en este tipo de dispositivos.
Adems de los eventos estndares como touchstart o touchend, han aadido una extensa
lista de eventos como tap, double tap, tap and hold, swipe, rotate o drag and drop.

Interoperabilidad con PhoneGap


Sencha Touch funciona perfectamente junto a PhoneGap (ver captulo correspondiente),
por lo que puede ser usado para distribuir nuestras aplicaciones en la App Store o en
Android Market. Se basa en el uso de un mecanismo que empotra nuestra aplicacin en
una shell nativa de la forma ms sencilla posible. Adems, gracias a PhoneGap podemos

71

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

hacer uso de la API nativa del dispositivo para acceder a la lista de contactos, la cmara y
muchas otras opciones directamente desde JavaScript.
Integracin de datos
Al igual que con ExtJS (biblioteca de JavaScript para el desarrollo de aplicaciones web
interactivas), Sencha Touch implementa el patrn de diseo MVC en el lado del cliente y
nos ofrece una API rica y poderosa para manejar flujos de datos desde una increble
variedad de fuentes. Podemos leer datos directamente a travs de AJAX, JSON, YQL o la
nueva capacidad local storage de HTML5. Podemos enlazar esos datos a elementos
especficos de nuestras vistas, y utilizar los datos sin conexin gracias a los almacenes
locales.

3.2. Sencha Touch vs. JQuery Mobile


A continuacin se enumeran las principales diferencias entre Sencha Touch y JQuery
Mobile:
Sencha Touch:
Tiene una curva de aprendizaje mucho mayor y necesita una mayor comprensin del
lenguaje de programacin JavaScript, pero gracias a esto proporciona una API mucho
ms potente.
Dispone de un mayor nmero de controles para la interfaz de usuario, as como
efectos de transicin y animaciones entre pginas mucho ms personalizables.
Ms rpido en mayor nmero de dispositivos mviles (en Android a partir de la
versin 2.1). El comportamiento y velocidad de Sencha Touch es mucho mejor que el
de otros frameworks, a excepcin del tiempo de carga inicial, pues JQuery Mobile
pesa menos.
Al estar basado en ExtJS (usan el mismo ncleo), es muy robusto y potente, adems
de ser un framework muy probado y usado (tambin debido a que fue uno de los
primeros en aparecer).
Al igual que en ExtJS, y en comparacin con JQuery Mobile, se escribe mucho. Esto
podra ser tomado como un pro o como un contra. Es bueno porque indica una mayor
potencia de configuracin y personalizacin, pero por contra conlleva ms tiempo de
desarrollo y de aprendizaje.
JQuery Mobile:
Muy sencillo de aprender y de implementar aplicaciones.
Es necesario escribir muy poco cdigo (y casi no se usa JavaScript) para lograr
aplicaciones mviles muy interesantes. En lugar de orientarse a la programacin
JavaScript, JQuery Mobile se centra en usar etiquetas HTML con atributos definidos
por el framework.
No dispone de muchos controles para el diseo de la interfaz.
Actualmente sigue en versin beta.
Tiene una ejecucin ms lenta en los dispositivos mviles. Se espera una mejora
72

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

sustancial cuando salga de fase beta.


Al estar basado en un framework muy desarrollado, como es JQuery, funciona
correctamente en un mayor nmero de dispositivos mviles y de navegadores, como
Symbian, Android, iOS, Blackberry, Window Phone 7 o WebOS.

Ambos frameworks son buenas opciones para el desarrollo de aplicaciones mviles. Los
dos utilizan HTML5, JavaScript e integran la tecnologa AJAX. La decisin depender de
las necesidades de la aplicacin a desarrollar. En principio, Sencha Touch es ms
apropiado para aplicaciones grandes, que necesiten de mayor personalizacin o
configuracin y que vayan a hacer un mayor uso del lenguaje de programacin
JavaScript. JQuery Mobile se suele utilizar para aplicaciones en las que se necesite una
interfaz de usuario que conecte directamente con un servidor y que haga un menor uso de
JavaScript.

3.3. Instalar Sencha Touch


En primer lugar descargamos el SDK de Sencha Touch desde su pgina Web
http://www.sencha.com/products/touch/download/. Tendremos que elegir si queremos
usar la licencia comercial o la Open-source, pero en ambos casos el contenido a descargar
ser el mismo. Se nos descargar un fichero comprimido con ZIP (llamado algo como
sencha-touch-VERSION.zip), que descomprimiremos en una carpeta de nuestro
servidor Web que renombraremos a touch.
Tambin es posible guardar el SDK de Sencha Touch en una carpeta diferente y
posteriormente crear un enlace simblico (llamado touch) hasta esta carpeta desde cada
uno de nuestros proyectos Web (ver siguiente apartado).
Una vez instalado podremos comprobar su correcto funcionamiento accediendo con
nuestro navegador a la direccin http://localhost/touch, con lo que veremos el contenido
de ejemplo que viene con el SDK de Sencha Touch:

73

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Sencha Touch solo funciona con navegadores basados en WebKit, como son: Safari,
Google Chrome, Epiphany, Maxthon o Midori. Si lo probamos en un navegador que no lo
soporte, como Firefox o Internet Explorer, solamente veremos una pgina en blanco o un
resultado errneo. Por lo tanto para probar nuestros proyectos Web tendremos que
instalar uno de los navegadores soportados, como Google Chrome
(http://www.google.es/chrome) o Apple Safari (http://www.apple.com/es/safari/).
Aunque la mayora de webs que podemos hacer con Sencha Touch se podran ejecutar y
visualizar directamente sin necesidad de un servidor Web, s que ser necesario su uso si
queremos probar nuestros proyectos utilizando algn emulador o un dispositivo mvil
real.
En la seccin inicial de Instalacin de un servidor Web se puede encontrar informacin
sobre la instalacin de un emulador mvil o la configuracin para el acceso externo
mediante un dispositivo mvil real.

3.4. Estructura de carpetas


Para crear un nuevo proyecto en primer lugar tenemos que crear una carpeta dentro de
nuestro servidor, por ejemplo hello-world como en la imagen inferior. Creamos un
fichero vaco dentro de esta carpeta llamado index.html que ser el fichero de inicio de
nuestro proyecto. Por ltimo tenemos que copiar (o enlazar) el SDK de Sencha Touch
dentro de un subdirectorio llamado lib/touch. Los pasos seran los siguientes:

74

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

$
$
$
$
$

mkdir hello-world // Nuevo proyecto


cd hello-world
touch index.html
mkdir lib
ln -s /home/code/web/SenchaSDK/sencha-touch-VERSION ./lib/touch

Finalmente la estructura de directorios queda como:

En la imagen se han marcado los ficheros index.html, sencha-touch.css y


sencha-touch.js, los cuales corresponden con el fichero inicial del proyecto, la hoja de
estilo a utilizar y la librera JavaScript de Sencha Touch.
Al desplegar nuestra aplicacin final no ser necesario copiar todo el cdigo de la librera
de Sencha Touch, sino solamente los recursos que utilicemos.

3.5. Cdigo HTML bsico de una aplicacin


Las aplicaciones de Sencha Touch se crean como un documento HTML5 que contiene
referencias a los recursos de JavaScript y CSS. Nuestro fichero index.html debe de
contener como mnimo el siguiente cdigo:

75

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Hello World</title>
<link href="lib/touch/resources/css/sencha-touch.css" rel="stylesheet"
type="text/css" />
<script src="lib/touch/sencha-touch.js" type="text/javascript"></script>
<script src="app/app.js" type="text/javascript"></script>
</head>
<body>
</body>
</html>

A continuacin analizaremos por separado cada una de las partes de este cdigo:
<!DOCTYPE html>
<html>
...
</html>

La primera lnea nos indica que este es un documento del tipo HTML5. Las etiquetas de
<html> y </html> indican el inicio y final del documento HTML y deben de contener en
su interior todo el resto del cdigo.
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Hello World</title>
...
</head>
<body>
</body>

Todo documento HTML (y HTML5 tambin) debe de contener primero una seccin de
cabecera (<head>) y a continuacin una seccin con el contenido principal o cuerpo del
documento (<body>). En este caso el cuerpo del documento (<body>) se encuentra vaco.
Esto se debe a que la librera Sencha Touch crea todo el contenido de la Web, incluidos
todos los elementos de la interfaz, mediante cdigo JavaScript.
La cabecera del documento (<head>) debe de contener como mnimo los metadatos
acerca del tipo de contenido, el conjunto de caracteres usados, y un ttulo que mostrar el
navegador en la parte superior de la ventana. Adems debe de contener los enlaces a las
libreras JavaScript y a la/s hoja/s de estilo usada/s:
<link href="lib/touch/resources/css/sencha-touch.css" rel="stylesheet"
type="text/css" />
<script src="lib/touch/sencha-touch.js" type="text/javascript"></script>
<script src="app/app.js" type="text/javascript"></script>

La etiqueta <link/> indica la localizacin de la hoja de estilo. Esta hoja de estilo se puede
cambiar o colocar en otra direccin diferente. La etiqueta <script></script> se utiliza para

76

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

cargar cdigo JavaScript en nuestra pgina Web. Primero se carga la librera se Sencha
Touch (localizada en lib/touch/sencha-touch.js) y a continuacin el cdigo de nuestra
aplicacin (app/app.js, que de momento est vaco).
Finalmente la estructura de carpetas de nuestro proyecto Web debera quedar como el de
la imagen siguiente:

Ahora ya tenemos cargadas las libreras de Sencha Touch y el cdigo de nuestra


aplicacin para empezar a trabajar. De momento, si lo visualizamos en un navegador solo
veremos una pgina en blanco.
Mostrar aviso durante la carga
Mientras que se carga la librera de Sencha Touch podemos mostrar fcilmente un texto o
una imagen. Para esto podemos aprovechar el cuerpo del documento (<body>) que hasta
ahora se encontraba vaco. Todo lo que incluyamos en esta seccin se visualizar
nicamente durante la carga, posteriormente ser ocultado por el contenido de la
aplicacin. En el siguiente ejemplo se ha creado un cuadro centrado en el que aparece el
texto "Cargando Aplicacin...".
<body>
<div style="margin:100px auto 0 auto; width:220px;
font-size:16pt;">
Cargando aplicacin...
</div>
</body>

3.6. Instanciar una aplicacin


Para realizar nuestro primer ejemplo vamos a crear una aplicacin que muestre en
pantalla el mensaje Hello World!, para lo cual abriremos el fichero app.js y
aadiremos el siguiente cdigo:
var App = new Ext.Application({
name: 'MyApp',
useLoadMask: true,

77

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

launch: function()
{
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
html: 'Hello World!'
});
}
});

A continuacin analizaremos por separado cada una de las partes de este cdigo:
var App = new Ext.Application({
name: 'MyApp',
launch: function()
{
...
}
});

Con new Ext.Application({ ... }); creamos una nueva instancia de Sencha Touch, es
decir, este es el constructor de nuestra aplicacin. Entre las llaves {} le pasaremos la
lista de opciones de configuracin para crear nuestra aplicacin. En primer lugar le damos
un nombre name: 'MyApp', con esto automticamente se crea una variable global
llamada MyApp junto con los siguientes namespaces:
MyApp
MyApp.views
MyApp.controllers
MyApp.models
MyApp.stores
Estos namespaces (o espacios de nombres) nos permitirn acceder a atributos de nuestra
aplicacin de forma sencilla, los iremos viendo en detalle ms adelante.
La funcin launch: function() { } solo se ejecuta una vez al cargar la aplicacin, y es
donde deberemos de colocar el cdigo necesario para definir nuestra interfaz de usuario.
MyApp.views.viewport = new Ext.Panel({
...
});

Con new Ext.Panel({ ....}); instanciamos un panel para nuestro contenido y se lo


asignamos al viewport de nuestra aplicacin. El viewport es la vista principal de la
aplicacin, dentro de la cual iremos aadiendo todo el contenido.
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
html: 'Hello World!'
});

Con la instruccin fullscreen: true le indicamos que debe ocupar toda la pantalla y con
html: 'Hello World!' el cdigo HTML que tiene que contener. Al poner fullscreen:

78

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

true tambin activamos la opcin monitorOrientation, para que se tengan en cuenta los
eventos de cambio de orientacin.
Con esto ya hemos creado nuestra primera aplicacin, un panel que ocupa toda la pantalla
con el texto Hello World!.
Nota:
Si queremos podemos definir la funcin launch como una funcin independiente. Dentro del
cdigo del panel simplemente tendremos que poner el nombre de la funcin a llamar, por
ejemplo: launch: crearViewPort (sin poner los parntesis de funcin). Y luego de forma
independiente definiramos la funcin function crearViewPort() {} con el resto del
cdigo. Esta es una buena prctica para modularizar nuestro cdigo.

3.7. Comprobando los resultados


Para comprobar el resultado de nuestra aplicacin podemos abrirla en un navegador
compatible con WebKit, como Chrome o Safari. Si abrimos el ejemplo de la seccin
anterior deberamos obtener algo como:

Si nuestro cdigo est en un servidor tambin podemos comprobar el resultado utilizando


un emulador de mvil, como en las imgenes inferiores:

79

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Estos emuladores son parte del IDE de Xcode y del SDK de Android. Para poder
utilizarlos necesitaremos tener nuestro cdigo en un servidor Web. Para ms informacin
consultar la seccin inicial Instalacin de un servidor Web y Emuladores.

3.8. Todo en un nico fichero


Para aplicaciones sencillas tambin es posible trabajar sin un servidor Web. Para esto
enlazaremos las libreras de Sencha Touch directamente desde su SDK online (asumiendo
que tenemos conexin a Internet), como en el siguiente fragmento:
<!DOCTYPE html>
<html>
<head>
<title>Hello World</title>
<link
href="http://cdn.sencha.io/touch/1.1.0/resources/css/sencha-touch.css"
rel="stylesheet" type="text/css" />
<script src="http://cdn.sencha.io/touch/1.1.0/sencha-touch.js"
type="text/javascript"></script>
<script type="text/javascript">
// Nuestro cdigo JavaScript
</script>
</head>
<body>
</body>
</html>

Este fichero lo podremos colocar en cualquier carpeta de nuestro ordenador y abrir


directamente con un navegador. No es la mejor forma de hacerlo, pero nos sirve para
probar cosas de forma rpida con un solo fichero.

3.9. Paneles y Layouts


En Sencha Touch el contenido se distribuye en paneles, los cuales actan de
contenedores de otros elementos y nos ayudan a distribuir el contenido. En primer lugar
deberemos definir el panel asignado a la vista principal, el viewport, dentro del cual
iremos aadiendo el resto de contenido y paneles.
Con new Ext.Panel({ .... }) creamos una instancia para un panel, dentro de este
constructor se incluirn los atributos necesarios para describir su contenido. Ya hemos
visto los atributos fullscreen: true y html: ..., ahora veremos que atributos tenemos

80

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

que usar para definir su disposicin o incluir otros paneles:


MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
html: 'Hola Mundo!',
layout: 'fit'
});

Este panel lo hemos definido para que ocupe toda la pantalla (fullscreen: true) y para que
los elementos se distribuyan en l ocupando todo el espacio disponible (layout: 'fit').
Los layouts especifican como se distribuyen los objetos que estn dentro de un panel.
Para utilizarlos simplemente tenemos que especificar su disposicin usando layout:
'valor' y alguno de los siguientes valores:
fit: los elementos se distribuyen consecutivamente ocupando todo el espacio
disponible.
card: los elementos se colocan de forma superpuesta, uno encima de otro. Este
elemento se utiliza para colocar paneles intercambiables, solo se visualizar uno a la
vez, y el resto se mostrarn al realizar alguna accin.
vbox: los elementos se distribuyen de forma vertical uno debajo de otro.
hbox: los elementos se distribuyen de forma horizontal.

Layouts soportados por Sencha Touch


Usando el atributo items: [ valores ] podemos aadir elementos al panel actual (como
otros paneles). La forma de referenciar estos elementos es a travs del espacio de
nombres: NombreAplicacin.view.NombrePanel o a travs de su identificador (como
veremos ms adelante). En el siguiente cdigo se crean dos paneles (panelSuperior y
panelInferior) que despus se aaden al panel principal usando la disposicin vbox:

81

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

MyApp.views.panelSuperior = new Ext.Panel({


html: 'Panel Superior'
});
MyApp.views.panelInferior = new Ext.Panel({
html: 'Panel Inferior'
});
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
layout: 'vbox',
items: [
MyApp.views.panelSuperior,
MyApp.views.panelInferior
]
});

Items de un panel
La propiedad items permite aadir elementos de diferentes formas:
Especificar un elemento o una lista de elementos utilizando su nombre:
items: [elemento]
items: [elemento1, elemento2]

Definir un elemento o una lista de elementos en lnea:


items: {}
items: [{...}, {...}]

Al crear un elemento en lnea, adems de especificar el resto de sus propiedades,


tambin tendremos que definir su tipo xtype (o tipo de objeto), de la forma:
items: { xtype: 'toolbar', dock: 'top' }

En todos los casos deberemos especificar un layout apropiado.

3.10. Identificadores
En todos los componentes de Sencha Touch podemos definir un identificador (id)
mediante el cual posteriormente podremos hacer referencia a ese elemento. La forma de
definirlo, por ejemplo, para un panel es la siguiente:
var panelSuperior = new Ext.Panel({
id: 'panelSuperior',
html: 'Panel Superior'
});

Posteriormente desde otro elemento podremos referirnos a este panel como


'panelSuperior', por ejemplo, para aadirlo como un tem en otro panel:
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
layout: 'card',
items: [ 'panelSuperior' ]

82

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

// Tambin podramos haber usado su nombre de variable, de la forma:


// items: [ panelSuperior ]
});

Este identificador podemos usarlo con todos los elementos: botones, barras, etc. Es una
buena prctica definirlo para todos los elementos que creamos que vayamos a referenciar
posteriormente. En este documento, por simplicidad, no lo incluiremos en todos los
ejemplos, solamente cuando sea necesario.
Cuando aparezca una referencia a otro elemento por su nombre de variable, tambin sera
posible hacerlo por su identificador. En algunos casos solo ser posible hacerlo por su
nombre de identificador, como veremos ms adelante.

3.11. Toolbars
Aadir barras de herramientas a un panel se realiza de forma muy similar a la forma de
aadir paneles a otro panel. En primer lugar tenemos que crear la barra de herramientas,
para esto utilizamos el constructor new Ext.Toolbar({ ... }). Dentro de este constructor
incluiremos los atributos necesarios para describir su contenido.
Algunos de los atributos que podemos utilizar son:
id: 'identificador': Atributo opcional para indicar el identificador de la barra.
dock: 'top' o dock: 'bottom': indica que la barra se coloque en la parte superior o en
la parte inferior del panel respectivamente.
title: 'texto': indica el texto que se colocar en el centro de la barra.
ui: valor: atributo opcional que cambia la apariencia de la barra. Por defecto toma el
valor dark, pero tambin podemos usar light que aplicar unos colores ms claros.
Para aadir estas barras a un panel utilizamos el atributo dockedItems: [ ... ],
referenciando
cada
barra
a
travs
del
espacio
de
nombres
(NombreAplicacin.view.NombreBarra) o a travs de su identificador.
En el siguiente ejemplo se crean dos barras de herramientas (topToolbar y
bottomToolbar) y despus se aaden a un panel usando para una el nombre de la variable
y para la otra su identificador:
MyApp.views.topToolbar = new Ext.Toolbar({
dock: 'top',
title: 'Top Toolbar'
});
var bottomToolbar = new Ext.Toolbar({
id: 'bottomToolbar',
dock: 'bottom',
title: 'Bottom Toolbar'
});
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
layout: 'fit',
html: 'Contenido central',
dockedItems: [

83

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

MyApp.views.topToolbar,
'bottomToolbar'

// Usamos su nombre de variable


// Usamos su identificador

]
});

Con lo que obtendramos un resultado similar a:

3.12. Docked items


Como ya hemos visto en la seccin anterior, dockedItems se utiliza para especificar uno
o ms elementos que sern anclados a una parte del panel. Los elementos que se suelen
anclar usando esta propiedad son: Toolbar y TabBar (como veremos ms adelante). Y
las posiciones que podemos usar son: top, bottom, left o right.
Los elementos se pueden aadir definindolos en lnea (hay que tener en cuenta que para
este caso tenemos que aadir su xtype):
dockedItems: [
{
xtype: 'toolbar',
dock: 'top',
title: 'barra superior'
}, {
xtype: 'toolbar',
dock: 'bottom',
title: 'barra inferior'
}
];

Pero por cuestiones de claridad ser mejor crear una definicin separada y aadirlos
posteriormente, como hemos visto en la seccin anterior:

84

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

var toolbar1 = new Ext.Toolbar({ dock: 'top', title: 't1' });


var toolbar2 = new Ext.Toolbar({ dock: 'top', title: 't2' });
MyApp.views.viewport = new Ext.Panel({
...
dockedItems: [ toolbar1, toolbar2 ]
});

En este ejemplo las dos barras de herramientas se colocan en la parte superior del panel.
Las barras se irn colocando una debajo de otra segn el orden en el que se aaden.

Tambin es posible manipular los elementos anclados mediante las funciones:


addDocked( item/array ): ancla un nuevo elemento al objeto desde el que se
referencia, por ejemplo: panel.addDocked( bottomToolbar );
removeDocked( item ): elimina un elemento anclado.
getDockedItems(): devuelve un array con los elementos anclados.

3.13. Botones
Los botones se aaden a las barras de herramientas (Toolbar) mediante su propiedad
items. Simplemente tendremos que definir el tipo de botn (ui) y el texto a mostrar
(text). En el siguiente ejemplo se crea una barra de herramientas con un botn y
posteriormente se aade al panel principal.
var topToolbar = new Ext.Toolbar({
dock: 'top',
title: 'mi barra',
items: [
{ ui: 'action', text: 'Nuevo' }
]
});
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
layout: 'fit',
dockedItems: [ topToolbar ]
});

Podemos usar siete tipos predefinidos de botones, estos son:


ui: 'back'
ui: 'forward'
ui: 'normal'
ui: 'round'
ui: 'action'

85

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

ui: 'confirm'
ui: 'decline'

Adems podemos usar los modificadores -small y -round sobre los tipos de botn
action, confirm y decline para obtener botones ms pequeos o redondeados:

Si no indicamos un tipo (ui) por defecto nos aparecer el botn tipo normal.
Si queremos variar el ancho de un botn podemos utilizar la propiedad width: '200px'
en pxeles o width: '95%' indicando porcentajes.
Iconos
Tambin podemos usar algunos iconos predefinidos, indicando el nombre del icono
mediante la propiedad iconCls: 'nombre' y activando iconMask: true para que el
icono se visualice correctamente, de la forma:
var button = new Ext.Button({
iconCls: 'action',
iconMask: true
});

Los iconos que podemos utilizar son:

action

add

arrow_down

arrow_left

arrow_right

arrow_up

compose

delete

organize

refresh

reply

search

86

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

settings

star

trash

maps

locate

home

Si adems usamos la propiedad text: 'texto' al definir el botn, el texto aparecer a la


derecha del icono:

Opcionalmente podemos aplicar colores a estos iconos, aplicndole los tipos (ui) de
'action', 'decline' o 'confirm', obteniendo:

Imgenes externas
Si queremos usar una imagen externa tenemos que aplicar al botn un estilo CSS. El
botn lo definimos de forma normal, pero utilizamos su propiedad cls para indicarle el
nombre del estilo:
items: [ { ui: 'normal', cls: 'btnAyuda' } ]

El estilo "btnAyuda" lo tendremos que definir indicando la imagen de fondo a usar junto
con el ancho y el alto del botn. El tamao de la imagen que usemos deber de coincidir
con el tamao aplicado al botn para que no se vea recortado. El tamao habitual de un
botn es de 45x35 pxeles. Adems es muy importante aadir en el CSS la propiedad
!important al cargar la imagen de fondo. Esto es debido a que Sencha Touch
sobrescribe algunos estilos y tenemos que aplicar esta propiedad para que prevalezca el
nuestro:
.btnAyuda {
background: url(imgs/ayuda.png) !important;
width: 45px;
height: 35px;
}

Badge
De forma sencilla podemos aadir una insignia distintiva a los botones para destacar
alguna informacin. Para esto utilizamos la propiedad badgeText: '2', que dara como
resultado:

87

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Alineaciones
Por defecto los botones salen alineados a la izquierda. Para crear otras alineaciones
utilizaremos un espaciador { xtype: 'spacer' }. En el siguiente cdigo podemos ver
diferentes ejemplos de alineaciones:
// Alineacin derecha
items: [
{ xtype: 'spacer' },
{ ui: 'normal', text: 'Botn' }
]
// Alineacin centrada
items: [
{ xtype: 'spacer' },
{ ui: 'normal', text: 'Botn' },
{ xtype: 'spacer' }
]

Acciones
Para aadir acciones a los botones tenemos que definir su propiedad handler, a la cual
le asignaremos una funcin. Esta funcin la podemos definir en lnea, de la forma
handler: function () { ... }, o creando una funcin independiente para separar
mejor el cdigo, como en el ejemplo:
function botonPresionado(btn, evt) {
alert("Presionado " + btn.text);
}
var topToolbar = new Ext.Toolbar({
items: [{
ui: 'normal',
text: 'Botn 1',
handler: botonPresionado
},
{
ui: 'action',
text: 'Botn 2',
handler: function(btn, evt) {
alert("Presionado " + btn.text);
}
}]
});

88

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

4. Ejercicios - Introduccin a Sencha Touch


En la seccin de ejercicios de Sencha Touch vamos a practicar creando una pequea
aplicacin mvil que nos permita gestionar un listado de notas. La pantalla principal
contendr el listado de notas, con botones que nos permitirn crear nuevas notas y
modificarlas. Al crear una nueva nota nos aparecer un formulario en el que podremos
introducir los datos y aadirlos al listado. Este mismo formulario tambin se utilizar para
modificar las notas existentes. Adems desde la pantalla principal podremos abrir la
ayuda con informacin sobre la aplicacin y los autores.
Si necesitas ayuda puedes descargar la plantilla para los ejercicios sesion02-ejercicios.zip.

4.1. Ejercicio 1 - Estructura de la aplicacin (0.5 puntos)


En este primer ejercicio vamos a empezar creando todos los ficheros que vamos a
necesitar: index.html, app.js y app.css. Por simplicidad los vamos a colocar en el mismo
directorio. El contenido de cada uno de los ficheros debe de ser el siguiente:
En index.html colocaremos el cdigo necesario para cargar la librera y la hoja de
estilo de Sencha Touch, junto con nuestro fichero de estilo app.css y nuestro fichero
de cdigo app.js. Adems, en el cuerpo del documento, aadiremos una capa (DIV)
con el texto "Cargando Mis Notas..." y le asignaremos el estilo "loading" que despus
definiremos en la hoja de estilo.
En app.css de momento solo vamos a definir el estilo de la clase loading: texto de
16pt, en color gris, centrado en la pgina y a 100px del borde superior.
En app.js es donde vamos a crear nuestra aplicacin y los paneles que necesitamos.
En primer lugar creamos la instancia de la aplicacin a la que pondremos como
nombre MisNotas. Aqu deberemos definir tambin la funcin launch, a la que
asignaremos una funcin independiente llamada crearViewPort. En la funcin
crearViewPort vamos a crear el panel principal y asignarlo al viewport. En este
panel de momento solo indicaremos que ocupe toda la pantalla y que muestre el texto
HTML "Mis Notas".

4.2. Ejercicio 2 - Creacin de paneles (0.5 puntos)


En este ejercicio vamos crear los paneles principales de la aplicacin, para esto vamos a
partir del cdigo del ejercicio anterior. Como ya hemos explicado vamos a tener un panel
para la lista de notas, otro para editar las notas y un tercero para mostrar la ayuda.
Adems vamos a necesitar un cuarto panel que se utilizar como contenedor. A
continuacin se explican los pasos que debemos seguir:
En app.js modificamos la funcin crearViewPort: asignamos al panel principal un
layout tipo card y en su seccin items incluimos los tres paneles de la aplicacin usando

89

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

su identificador, a los que llamaremos 'panelContenedorLista', 'panelFormulario' y


'panelAyuda'.
Estos paneles ('panelContenedorLista', 'panelFormulario' y 'panelAyuda') los definiremos
de la misma forma, un panel, con el identificador apropiado, un layout tipo fit y un texto
html de prueba que utilizaremos para comprobar que el panel se visualiza correctamente.
Por ltimo deberemos comprobar que todo funciona correctamente. Para comprobar cada
uno de los paneles recordad que tenemos que cambiar su orden en la seccin items del
viewport, pues solo se visualizar el primero de ellos.

4.3. Ejercicio 3 - Barras de herramientas (1 punto)


Este ejercicio continua con el anterior, al cual vamos a aadir las barras de herramientas
necesarias para cada panel. Las barras las instanciaremos como un objeto separado y
despus las aadiremos a los paneles usando su identificador:
En el panel 'panelContenedorLista' aadiremos una barra en la parte superior con el
ttulo "Mis Notas" y el identificador 'panelListaToolbar'.
En el panel 'panelFormulario' aadiremos dos barras de herramientas. Una en la parte
superior con el ttulo "Editar nota" y el identificador 'panelFormularioTopToolbar'. Y
una segunda barra en la parte inferior con el identificador
'panelFormularioBottomToolbar' y sin ningn ttulo.
Por ltimo para el panel 'panelAyuda' aadiremos una barra en su parte superior con
el ttulo "Ayuda" y el identificador 'panelAyudaToolbar'.

4.4. Ejercicio 4 - Botones (1 punto)


En este ltimo ejercicio vamos a aadir los botones de cada una de las barras de
herramientas que hemos definido en el ejercicio anterior. Recordad que para aadir
botones a una barra de herramientas tenemos que aplicarles el layout: 'hbox' y que los
botones irn definidos en su seccin items.
En el panel 'panelAyuda' vamos a poner un nico botn en su barra de herramientas
alineado a la izquierda, en el que colocaremos el icono predefinido de tipo 'home'.
En el panel 'panelContenedorLista' vamos a colocar dos botones en su barra de
herramientas. El primer botn estar alineado a la izquierda y contendr una imagen
externa (subcarpeta "imgs" de la plantilla). Para aadir esta imagen tendremos que
asignar un estilo al botn, llamado "btnAyuda" (ver seccin "Botones"). Este estilo lo
definiremos en nuestra hoja de estilo "app.css" para que cargue la imagen indicada
(recordad usar !important) con un ancho de 45 pxeles y un alto de 35 pxeles.
El segundo botn del panel 'panelContenedorLista' estar alineado a la derecha, con el
tipo 'action' y el texto "Nueva Nota".
Por ltimo en el panel 'panelFormulario' tenamos dos barras de herramientas. En la
barra superior colocaremos dos botones. El primero de ellos estar alineado a la
izquierda, con el icono predefinido de tipo 'home'. El segundo botn de esta barra
90

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

estar alineado a la derecha, ser de tipo 'action' con el texto "Guardar". En la barra
inferior colocaremos otro botn alineado a la derecha y con el icono predefinido de
tipo 'trash'.

91

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

5. Sencha Touch
5.1. Transiciones de cambio de vista
En este apartado vamos a ver como cambiar entre diferentes paneles. Nuestra aplicacin
tendr una vista principal y al apretar sobre algn botn, cambiaremos a una vista o panel
diferente. Para hacer esto lo ms importante es utilizar un panel base no visible (asignado
al viewport), el cual contendr como items los paneles entre los que queremos
cambiar. Adems tenemos que establecer el layout del panel base a layout: 'card',
quedando el cdigo de nuestro viewport de la forma:
MyApp.views.viewport = new Ext.Panel({
fullscreen: true,
layout: 'card',
items: [
'panel1',
'panel2'
]
});

El panel que se ver al principio es el primero que se aade a la lista de tems, quedando
el otro (o los otros) ocultos. Tambin es muy importante fijarse que estamos
referenciando los paneles por su identificador, y no directamente por la variable, de no
hacerlo as se podran producir comportamientos inesperados en las animaciones.
En la siguiente imagen se puede ver un esquema del intercambio de paneles (en nuestro
ejemplo con dos paneles). El panel asignado al viewport queda como un contenedor
invisible por detrs, y mediante un botn podemos pasar de un panel a otro:

92

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

A continuacin se incluye el cdigo para el panel1. Un simple panel con una barra de
herramientas en la parte superior que contiene un botn. Lo ms importante aqu es la
funcin
handler
del
botn,
en
la
cual
llamamos
a
MyApp.views.viewport.setActiveItem (funcin explicada a continuacin) para
cambiar al panel2 utilizando una animacin slide. El cdigo para el panel2 sera
exactamente igual, pero intercambiando los identificadores.
var panel1 = new Ext.Panel({
id: 'panel1',
fullscreen: true,
layout: 'fit',
html: 'Panel 1',
dockedItems: [{
xtype: 'toolbar',
items: [{
ui: 'forward',
text: 'Adelante',
handler: function() {
MyApp.views.viewport.setActiveItem(
'panel2',
{type: 'slide', direction: 'up', duration: 2000});
}
}] // end items
}] // end dockedItems
});

Mtodo setActiveItem
La funcin setActiveItem( panelID, atributos_animacin ) solo est definida

93

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

para los paneles que tienen un layout tipo card. Permite cambiar entre el panel activo o
visible por otro panel indicado utilizando una animacin. El primer argumento de esta
funcin es el identificador del panel que queremos colocar en primer plano. Y el segundo
argumento es el tipo de animacin utilizada para intercambiar los paneles. Los tipos de
animaciones que podemos utilizar son:
fade: difumina el panel actual, fundindolo con el panel de destino, hasta completar la
transicin.
pop: realiza una especie de animacin 3D. Escala el panel actual minimizndolo hasta
ocultarlo, mientras que aumenta el tamao del panel a visualizar.
slide: realiza un desplazamiento para intercambiar un panel por otro, podemos indicar
una direccin: left, right, up, down (por ejemplo: direction: 'left').
flip: realiza una animacin 3D para intercambiar los paneles.
cube: realiza una animacin 3D para intercambiar los paneles.
wipe: realiza un barrido para el intercambio. No funciona correctamente.
Para todos ellos podemos definir una duracin en milisegundos (por ejemplo duration:
2000).
Nota: Las animaciones flip, cube y wipe no funcionan correctamente en Android.

5.2. TabBar
Los TabBar son muy similares a las barras de herramientas, las cuales tambin se aaden
a un panel anclndolas mediante dockedItems. La apariencia visual es diferente, con
una superficie ms plana (con menos sombra que las ToolBar). Se usan para crear
botones de texto ms grandes (o reas pulsables), los cuales no tendrn aspecto de botn
sino que formarn parte de la barra. Por esta razn los botones no admiten la propiedad
ui, pero s que la podemos usar para cambiar la apariencia de la barra (ui:'dark' o
ui:'light'). Estas barras tampoco soportan el atributo title.
En el siguiente ejemplo se ha aadido un TabBar en la parte de abajo de un ToolBar (solo
se incluye el cdigo del TabBar):
var bar = new Ext.TabBar({
dock : 'top',
ui : 'light',
items: [
{ text: '1st Button' },
{ text: '2nd Button' }
]
});

Con lo que obtendramos un resultado similar al de la siguiente imagen:

94

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Podemos usar la propiedad width para definir el ancho de los tabs en pxeles o en
porcentaje, por ejemplo: width: '50%'.
Para aadir acciones a los tabs tenemos que definir su propiedad handler, asignndole
una funcin, de la forma:
var bar = new Ext.TabBar({
dock : 'top',
items: [{
text: '2nd Button',
handler: function() {
alert("Tab presionado");
}
}]
});

5.3. Carousel
El Carousel es un contenedor de paneles que nos permite cambiar entre ellos simplemente
arrastrando el dedo. Solo se muestra un panel en cada momento junto con un pequeo
indicador con puntos que referencia el nmero de paneles disponibles.
Es muy sencillo configurarlo, en su seccin tems tenemos que definir cada uno de los
paneles. Si queremos que se utilicen los estilos HTML bsicos tenemos que activar la
opcin defaults: { styleHtmlContent: true }, como en el siguiente ejemplo:
var panelCarousel = new Ext.Carousel({
fullscreen: true,
defaults: {
styleHtmlContent: true
},
items: [
{
html :
style:
},
{
html :
style:
},
{
html :
}
]

'Item 1',
'background-color: #5E99CC'
'Item 2',
'background-color: #759E60'
'Item 3'

});

95

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Con lo que obtendramos un resultado como el siguiente:

Una opcin interesante de configuracin es la orientacin del panel, que bsicamente lo


que hace es cambiar la posicin de los puntos y la direccin de movimiento de los
paneles. Para configurarlo usamos la propiedad direction: 'vertical' (por defecto) o
direction: 'horizontal'.

5.4. MessageBox
Esta clase nos permite generar mensajes emergentes de tres tipos: alertas, confirmacin y
de campo de texto.
5.4.1. Alertas
Muestra un mensaje de aviso con un solo botn OK, como podemos ver en la imagen
siguiente:

96

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Para

crear

una

ventana

de
aviso
usamos
el
constructor
Ext.Msg.alert(title,msg,function), el primer parmetro es el ttulo de la ventana,
el segundo es el mensaje de aviso que aparecer en el centro de la ventana, y el ltimo es
la funcin callback que se llamar una vez cerrada la ventana.
Ext.Msg.alert('Titulo', 'Mensaje de aviso', Ext.emptyFn);

En este caso usamos la funcin vaca Ext.emptyFn para que no se ejecute nada. En su
lugar podramos haber puesto directamente el nombre de una funcin.
5.4.2. Confirm
Este mensaje de aviso nos da la opcin de aceptar o rechazar, como podemos ver en la
siguiente imagen:

En este caso utilizamos el constructor Ext.Msg.confirm(title,msg,function), los


parmetros sern los mismos: ttulo, mensaje y funcin. En este caso s que nos interesa
indicar el nombre de una funcin para poder comprobar si se ha pulsado el OK. La
funcin callback recibir un nico parmetro cuyo valor ser el texto del botn pulsado.
function myFunction(btn)
{
if( btn == "yes" )
alert( "Confirmed!" );
}
Ext.Msg.confirm( "Confirmation", "Are you sure you want to do that?",
myFunction );

5.4.3. Prompt
El mensaje de campo de texto sirve para solicitar un dato al usuario, consiste en una
pequea ventana con un campo de texto que se puede aceptar o rechazar:

97

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Utilizamos el constructor Ext.Msg.prompt(title,msg,function) con los parmetros:


ttulo, mensaje y funcin. En este caso la funcin callback recibir dos parmetros: el
botn pulsado y el texto introducido.
function myFunction(btn, text)
{
alert( btn + ' ' + text );
}
Ext.Msg.prompt('Name', 'Please enter your name:', myFunction );

5.5. Formularios
Para crear formularios utilizamos el constructor Ext.form.FormPanel(parmetros), el
cual se comporta exactamente igual que un panel, pero permitiendo aadir fcilmente
campos en el array items. En el siguiente ejemplo se crea un formulario que contiene
un campo de texto y un rea de texto.
var noteEditor = new Ext.form.FormPanel({
id: 'noteEditor',
items: [
{
xtype: 'textfield',
name: 'title',
label: 'Title',
required: true
},
{
xtype: 'textareafield',
name: 'narrative',
label: 'Narrative'
}
]
});

98

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

5.5.1. Tipos de campos


Para todos los campos podemos especificar un nombre name, una etiqueta label y si
es requerido required:true (esta propiedad solo es visual, aade un asterisco (*) en el
nombre del campo, pero no realiza ninguna validacin).
El nombre (name) se utiliza para cargar y enviar los datos del formulario (como veremos
ms adelante), y la etiqueta (label) se mostrar visualmente en la parte izquierda de cada
campo. El valor de todos los campos se encuentra en su atributo value, el cual tambin
podemos utilizarlo para especificar un valor inicial.
Los principales tipos de campos que podemos utilizar son los siguientes (indicados segn
su nombre xtype en negrita):
textfield: campo de texto.

textareafield: rea de texto.

passwordfield: campo de texto para introducir contraseas. El cdigo es igual que


para un textfield pero cambiando el valor de xtype: 'passwordfield':

urlfield: campo de texto para direcciones Web, incluye validacin de URL correcta:

emailfield: campo de texto para introducir e-mails, incluye validacin automtica:

togglefield: permite seleccionar entre dos valores (0 1). Por defecto se encuentra
desactivado, para activarlo por defecto tenemos que aadir value:1 a la definicin
del campo:

numberfield: campo numrico, permite introducir el nmero manualmente o


mediante las flechas laterales. Inicialmente no contiene ningn valor, pero podemos
definir un valor inicial mediante la propiedad value: 20:

spinnerfield: campo numrico, permite introducir el nmero manualmente o

99

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

mediante los botones laterales. Inicialmente su valor es 0. Podemos definir un valor


inicial mediante la propiedad value: 20. Tambin podemos definir un valor
mnimo minValue: 0, un valor mximo maxValue: 100, el incremento
incrementValue: 2 y si se permiten ciclos cycle: true.

sliderfield: campo numrico modificable mediante una barra o slider. Inicialmente su


valor es 0. Podemos definir un valor inicial mediante la propiedad value: 50.
Tambin podemos definir un valor mnimo minValue: 0, un valor mximo
maxValue: 100 y el incremento incrementValue: 2.

datepickerfield: campo para seleccionar fechas. Al pulsar sobre el campo aparece


una ventana en la que podemos seleccionar fcilmente una fecha. Podemos indicarle
una fecha inicial utilizando value: {year: 1989, day: 1, month: 5}:

fieldset: Este elemento en realidad no es un campo de datos, sino un contenedor. No


aade ninguna funcionalidad, simplemente pone un ttulo (opcional), y agrupa
elementos similares, de la forma:
items: [{
xtype: 'fieldset',
title: 'About Me',
items: [
{ xtype: 'textfield', name : 'firstName', label: 'First Name' },
{ xtype: 'textfield', name : 'lastName', label: 'Last Name'}
]
}]

Con lo que obtendramos un resultado similar a:

selectfield: campo desplegable para seleccionar entre una lista de valores. Las
posibles opciones se indican en la propiedad options como un array. Para cada
opcin tenemos que indicar sus valores text (texto que se mostrar) y value (valor
devuelto para la opcin seleccionada).

100

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

items:[{
xtype: 'selectfield',
label: 'Select',
options: [
{text: 'First Option', value: 'first'},
{text: 'Second Option', value: 'second'},
{text: 'Third Option', value: 'third'}
]
}]

Con lo que obtendramos un resultados como el siguiente:

checkboxfield: el campo checkbox nos permite elegir uno o varios elementos de una
lista. Cada campo de la lista se tiene que declarar como un item independiente, pero
todos ellos deben de tener el mismo nombre name para poder ser agrupados (muy
importante para posteriormente poder recoger los datos correctamente). Adems
podemos utilizar la propiedad checked: true para que aparezcan marcados
inicialmente:
items: [
{
xtype: 'checkboxfield',
name : 'check_color', // Nombre del grupo
value: 'red',
label: 'Red',
checked: true
}, {
xtype: 'checkboxfield',
name : 'check_color',
value: 'green',
label: 'Green'
}, {
xtype: 'checkboxfield',
name : 'check_color',
value: 'blue',
label: 'Blue'
}
]

Con lo que obtendramos un resultado como el siguiente:

101

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

radiofield: el campo de tipo radio nos permite elegir solo un elemento de una lista.
Cada campo de la lista se tiene que declarar como un item independiente, pero todos
ellos deben de tener el mismo nombre name para poder ser agrupados (muy
importante para posteriormente poder recoger los datos correctamente). Adems
podemos utilizar la propiedad checked: true en uno de ellos para que aparezca
marcado inicialmente:
items: [
{
xtype: 'radiofield',
name : 'radio_color',
value: 'red',
label: 'Red',
checked: true
}, {
xtype: 'radiofield',
name : 'radio_color',
value: 'green',
label: 'Green'
}, {
xtype: 'radiofield',
name : 'radio_color',
value: 'blue',
label: 'Blue'
}
]

// Nombre del grupo

Con lo que obtendramos un resultado similar a:

Tambin podemos instanciar los campos de un formulario de forma independiente


utilizando su constructor, por ejemplo para el campo de textfield sera
Ext.form.Text, o para el campo togglefield sera Ext.form.Toggle. En
general el constructor tendr el mismo nombre que su tipo xtype pero quitando el
sufijo field.

102

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

6. Ejercicios - Sencha Touch


En esta sesin vamos a continuar con el ejercicio del editor de notas de la sesin anterior,
al cual aadiremos el contenido de la ayuda, el panel con el formulario y definiremos las
transiciones entre paneles.
Si necesitas ayuda puedes descargar la plantilla para los ejercicios sesion03-ejercicios.zip.

6.1. Ejercicio 1 - Transiciones (1 punto)


Partiendo del cdigo del ltimo ejercicio vamos a aadir las acciones de transicin que
nos permitirn movernos entre paneles. Todas las transiciones que apliquemos sern del
tipo 'slide' y con una duracin de 1 segundo (1000ms).
Al presionar el botn del panel 'panelAyuda' realizaremos una transicin hacia arriba
para cambiar al panel 'panelContenedorLista'.
En el panel 'panelContenedorLista' tenemos dos botones en su barra de herramientas.
Para el primer botn alineado a la izquierda definimos una transicin hacia abajo que
cargue el panel 'panelAyuda'. El segundo botn cargar el panel 'panelFormulario' con
una transicin hacia la izquierda.
Por ltimo, para los tres botones del panel 'panelFormulario' asignaremos la misma
transicin hacia la derecha para cambiar al panel 'panelContenedorLista'.

6.2. Ejercicio 2 - Contenido de la ayuda (1 punto)


En este ejercicio vamos a completar el panel de ayuda. En primer lugar modificamos su
constructor para que sea del tipo Carousel y definimos su seccin items para que
contenga dos paneles. Adems tenemos que quitar tambin los campos layout: fit y el
texto HTML que tenamos puesto de prueba.
El contenido HTML de cada uno de estos paneles del Carousel lo definiremos en una
variable independiente (llamadas var htmlAyuda1 y var htmlAyuda2), que
posteriormente asignaremos al elemento html del panel correspondiente. Recordad que
para concatenar cadenas tendremos que usar el smbolo ms (+).
Para el HTML del primer panel del Carousel definiremos una capa (DIV) a la que
asignaremos el estilo ".ayuda". Dentro de esta capa colocaremos el ttulo "Mis Notas" (de
tipo H1), seguido por un par de prrafos con el texto "Aplicacin Web para la gestin de
notas realizada con Sencha Touch. Experto en Desarrollo de Aplicaciones para
Dispositivos Mviles". Y por ltimo abajo colocaremos una imagen con un ancho de 100
pxeles (subcarpeta "imgs" de la plantilla).
Para el segundo panel utilizaremos tambin una capa de la clase ".ayuda", en la que
colocaremos el titular "Autor", seguido por unos prrafos con los datos del autor.

103

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Para dar formato a este texto tendremos que modificar el fichero app.css aadiendo los
siguientes estilos:
.ayuda: la clase ayuda la definiremos con un ancho del 100% y un texto centrado.
.ayuda h1: la etiqueta H1 (cuando est dentro de la clase "ayuda") la definiremos con
un color azul oscuro (navy), un tamao de 18 puntos, y el estilo "uppercase" para que
aparezca siempre en maysculas.
.ayuda p: la etiqueta P la definiremos para que tenga color gris (gray).

6.3. Ejercicio 3 - Panel con Formulario (1 punto)


En este ejercicio vamos a crear el formulario. Para esto editamos el panel
'panelFormulario' que ya tenamos hecho, y le cambiamos el constructor de panel por uno
de tipo formulario. Adems tenemos que quitar tambin los campos layout: fit y el
texto HTML que tenamos puesto de prueba. En este formulario vamos a aadir dos
campos:
Un campo de texto con el nombre 'title', con la etiqueta "Ttulo:" y activaremos la
opcin de requerido.
Un rea de texto con nombre 'text', etiqueta "Texto:" y que tambin sea requerido.

104

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

7. Aspectos avanzados de Sencha Touch


7.1. Data Model
Los modelos de datos nos permiten representar objetos, junto con sus validaciones de
formato y las relaciones que estos tienen con otros objetos. Por comparacin podramos
pensar que un Data Model es como una clase (en POO) con la definicin de los datos que
la componen y funciones para poder validar y trabajar con esos datos.
Para usarlos tenemos que crear una instancia de Ext.regModel(name,
fields_description), en la que primero se indica el nombre del modelo o identificador
(en el ejemplo siguiente sera Users), y a continuacin los campos que lo componen
({idProperty, fields}):
Ext.regModel('Users', {
// Nombre del modelo: Users
idProperty: 'id',
// Descripcin de los campos que lo componen
fields: [
{ name: 'id', type: 'int' },
{ name: 'usuario', type: 'string' },
{ name: 'nombre', type: 'string' },
{ name: 'genero', type: 'string' },
{ name: 'activo', type: 'boolean', defaultValue: true},
{ name: 'fechaRegistro', type: 'date', dateFormat: 'c' },
]
});

Con idProperty: 'id' definimos el campo que se va a utilizar como identificador


nico. Es recomendable indicarlo siempre porque para algunos tipos de almacenamiento
es necesario.
En la seccin fields se definen el resto de campos que componen el modelo:
name: nombre o identificador del campo.
type: los campos pueden ser de cinco tipos: string, int, float, boolean, date.
defaultValue: atributo opcional que nos permite indicar el valor por defecto de un
campo.
dateFormat: atributo opcional mediante el cual podemos indicar el formato de la
fecha (ver http://docs.sencha.com/touch/1-1/#!/api/Date).
7.1.1. Validaciones
Los modelos de datos incluyen soporte para realizar validaciones, las cuales las
deberemos de incluir dentro de la misma clase regModel a continuacin del campo
fields. Continuando con el ejemplo anterior:
fields: [ ... ],
validations: [

105

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

{field:
{field:
{field:
{field:
{field:
]

'id', type: 'presence' },


'usuario', type: 'exclusion', list: ['Admin', 'Administrador']},
'usuario', type: 'format', matcher: /([a-z]+)[0-9]{2,3}/},
'nombre', type: 'length', min: 2},
'genero', type: 'inclusion', list: ['Masculino', 'Femenino']}

Los tipos de validaciones que podemos utilizar son los siguientes:


presence: Indica que el campo es requerido.
length: Valida la longitud del campo. Podemos indicar como atributos un mnimo
(min) y/o un mximo (max).
exclusion: Valida que el valor del campo no se encuentre entre la lista de valores
especificados en list.
inclusion: Valida que el valor del campo se encuentre entre la lista de valores
especificados en list.
format: Permite especificar una expresin regular (mediante el atributo matcher) para
validar el campo.
Adems, definiendo definiendo el valor de la propiedad message, podemos cambiar el
mensaje de error que se producira si una validacin no es correcta:
{ field: 'titulo', type: 'presence',
message: 'Por favor, introduzca un ttulo' }

Cuando trabajemos con un formulario y queramos comprobar estas validaciones lo


tendremos que hacer manualmente llamando a la funcin validate(), esta opcin la
veremos ms en detalle en la seccin de formularios.
7.1.2. Crear una instancia de un modelo
Para crear una instancia de un modelo utilizamos
Ext.ModelMgr.create(lista_valores, nombre_modelo):

el

constructor

var instance = Ext.ModelMgr.create({


id: 1,
usuario: 'javierGallego',
nombre: 'Antonio Javier Gallego Snchez',
genero: 'Male',
fechaRegistro: new Date()
}, 'Users');

7.1.3. Ms informacin
Para ms informacin sobre validaciones:
http://docs.sencha.com/touch/1-1/#!/api/Ext.data.validations
Los modelos de datos tambin soportan la creacin de relaciones con otros modelos de
datos, del tipo has-many y belongs-to. Para ms informacin consultar la API:
http://docs.sencha.com/touch/1-1/#!/api/Ext.data.Model
106

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

7.2. Data Store


Los almacenes de datos (data store) se utilizan para encapsular o almacenar los datos de
un modelo dado en la cach del cliente. Estos datos se cargan y escriben utilizando un
proxy. Adems disponen de funciones para ordenar, filtrar y consultar los datos.
Crear un almacn de datos es fcil, simplemente tenemos que indicarle el modelo de
datos a usar y el proxy para cargar y guardar los datos. Dependiendo del proxy que
utilicemos podremos almacenar los datos de forma local o de forma remota:
7.2.1. Almacenamiento en local
Para este tipo de almacenamiento, el proxy utiliza la nueva funcionalidad de HTML5 de
almacenamiento en local. Esta opcin es muy til para almacenar informacin sin la
necesidad de utilizar un servidor. Sin embargo solo podremos guardar pares clave-valor,
no soporta objetos complejos como JSON (JavaScript Object Notation).
Al usar almacenamiento en local es muy importante que el modelo de datos tenga un id
nico, que por defecto tendr ese nombre de campo (id); en caso de utilizar otro lo
podramos indicar mediante la propiedad idProperty: 'myID'.
Para que el proxy utilice el almacenamiento en local simplemente tendremos que indicar
el tipo (localstorage) y un identificador (usado como clave para guardar los datos).
En el siguiente ejemplo se crea un almacn de datos para el modelo Users que hemos
definido en la seccin anterior. Adems hemos aadido la propiedad autoLoad: true,
muy importante para que se carguen los datos al inicio desde el proxy indicado. Si no lo
hiciramos as el Store inicialmente estara vaco.
var myStore = new Ext.data.Store({
model: 'Users',
autoLoad: true,
proxy: {
type: 'localstorage',
id: 'notes-app-localstore'
}
});

Una forma alternativa de instanciar un Store es: Ext.regStore( 'myStore', { ... }


); de forma similar a como lo hacamos con los Data Models.
7.2.2. Almacenamiento en remoto
En el siguiente ejemplo se crea un almacn de datos que trabaja con ficheros tipo JSON
que estn almacenados en remoto:
var myStore = new Ext.data.Store({

107

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

model: 'Users',
autoLoad: true,
proxy: {
type: 'ajax',
url : '/users.json', // URL remota del fichero
reader: {
type: 'json',
root: 'usersList'
}
}
});

El proxy utiliza AJAX para cargar los datos desde la direccin ./users.json. La
propiedad reader indica al proxy como debe decodificar la respuesta que obtiene del
servidor a travs de la consulta AJAX. En este caso espera que devuelva un objeto del
tipo JSON que contiene un array de objetos con los mismos campos que se indican en el
modelo Users y que adems dicho array tiene como raz usersList. Por simplificar,
si nuestro modelo Users solamente tuviera los campos id y name esperara un fichero
como el siguiente:
{"usersList": [
{
"id": 1, "name": "Javier Gallego"
},
{
"id": 2, "name": "Fran Garca"
}
]}

Para ms informacin sobre JSON:


http://docs.sencha.com/touch/1-1/#!/api/Ext.data.JsonReader
7.2.3. Aadir datos
Es muy sencillo aadir datos directamente junto a la definicin de un Store, solo tenemos
insertarlos como un array a travs de su propiedad data. Suponiendo que el modelo
Users solo tuviera dos campos (id, name), podramos aadir datos de la forma:
var myStore = new
model: 'Users',
data: [
{id: 1, name:
{id: 2, name:
{id: 3, name:
{id: 4, name:
]
});

Ext.data.Store({
'Javier Gallego'},
'Fran Garca'},
'Boyan Ivanov'},
'Miguel Lozano'}

O tambin podemos aadir datos posteriormente llamando a la funcin add del objeto:
myStore.add({id: 5, name: 'Javier Aznar'},
{id: 6, name: 'Pablo Suau'});

108

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

7.2.4. Ordenar y Filtrar elementos


Para ordenar y filtrar los datos usamos las propiedades sorters y filters. En el
siguiente ejemplo se ordenan los datos de forma descendente por nombre de usuario
(tambin podra ser ASC) y se realiza un filtrado por gnero (los filtros tambin admiten
expresiones regulares).
var myStore = new Ext.data.Store({
model: 'Users',
sorters: [
{ property: 'usuario', direction: 'DESC' }
],
filters: [
{ property: 'genero', value: 'Femenino' }
]
});

7.2.5. Buscar registros


En algunos casos antes de aadir un registro ser necesario comprobar si el registro est
repetido. Para esto podemos utilizar el mtodo findRecord(campo, valor) del Store, el
cual devuelve el registro encontrado o null en caso de no encontrar ninguna coincidencia.
En el siguiente ejemplo se compara el campo id de los datos del Store, con el campo id
del registro a aadir:
if (myStore.findRecord('id', registro.data.id) === null)
{
myStore.add( registro );
}

Otra opcin para buscar registros es la funcin find(campo, valor) la cual devuelve el
ndice del registro encontrado, y posteriormente podramos llamar a getAt(index) para
obtener los datos.
7.2.6. Eliminar registros
Para eliminar un registro de un Store usaremos la funcin remove(registro), por
ejemplo:
myStore.remove( registro );

Es recomendable comprobar si existe el registro a eliminar, para esto usaremos la funcin


findRecord(). Normalmente el Store estar asignado a algn panel que nos permita ver
los datos (como un listado). Si quisisemos eliminar un registro de este listado, primero
tendramos que obtener el Store usado, a continuacin comprobar si existe el registro y si
es as eliminarlo. Por ltimo habra que sincronizar los datos para que se visualicen, de la
forma:

109

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

var store = miListado.getStore();


if( store.findRecord('id', registro.data.id) )
{
store.remove( registro );
}
store.sync();
miListado.refresh();

Tambin podemos utilizar la funcin removeAt(index) para eliminar los registros de un


Store a partir de su ndice.
7.2.7. Ms informacin
Para ms informacin sobre los almacenes de datos consultar:
http://docs.sencha.com/touch/1-1/#!/api/Ext.data.Store

7.3. Plantillas
Las plantillas se utilizan para describir la disposicin y la apariencia visual de los datos de
nuestra aplicacin. Nos proporcionan funcionalidad avanzada para poder procesarlos y
darles formato, como: auto-procesado de arrays, condiciones, operaciones matemticas,
ejecucin de cdigo en lnea, variables especiales, funciones, etc.
Para instanciar un template utilizamos el constructor Ext.XTemplate( template ),
donde template ser una cadena con la definicin del template a utilizar. Posteriormente
podemos utilizar la funcin overwrite(elemento, datos) del template para aplicar un
template con unos datos sobre un elemento dado. En la seccin de Visualizacin se
detalla otra forma de aplicar un template en un panel.
7.3.1. Auto-procesado de arrays
Para crear un template que procese automticamente un array se utiliza la etiqueta <tpl
for=variable>plantilla</tpl>, teniendo en cuenta que:
Si el valor especificado es un array se realizar un bucle por cada uno de sus
elementos, repitiendo el cdigo de la plantilla para cada elemento.
La plantilla puede contener texto, etiquetas HTML y variables o elementos del
array a sustituir.
Las variables a sustituir se indican de la forma {nombre_variable}, donde
nombre_variable debe de corresponder con el nombre de una de los elementos del
array iterado.
Mediante la variable especial {#} podemos para obtener el ndice actual del array.
En la seccin for="variable" de la plantilla se debe de indicar el nombre de la
variable que contiene el array a procesar, de la forma:
Con <tpl for=".">...</tpl> se ejecuta un bucle a partir del nodo raz.

110

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Con <tpl for="foo">...</tpl> se ejecuta el bucle a partir del nodo foo.


Con <tpl for="foo.bar">...</tpl> se ejecuta el bucle a partir del nodo
foo.bar

Si por ejemplo tenemos el siguiente objeto de datos:


var myData = {
name: 'Tommy Maintz',
drinks: ['Agua', 'Caf', 'Leche'],
kids: [
{ name: 'Toms', age:3 },
{ name: 'Mateo', age:2 },
{ name: 'Salomn', age:0 }
]
};

Podramos mostrar un listado con el contenido de myData.kids indicando en la seccin


for="variable" que procese a partir de la raz del array a procesar (myData.kids):
var myTpl = new Ext.XTemplate(
'<tpl for=".">',
'<p>{#}. {name}</p>',
'</tpl>' );
myTpl.overwrite(panel.body, myData.kids);

Si por ejemplo indicamos que se procese la variable myData y queremos obtener el


mismo resultado, tendramos que modificar el template para que se procese a partir del
nodo kids, de la forma <tpl for="kids">...</tpl>.
var myTpl = new Ext.XTemplate(
'<tpl for="kids">',
'<p>{#}. {name}</p>',
'</tpl>' );
myTpl.overwrite(panel.body, myData);

Si el array solo contiene valores (en el objeto de datos de ejemplo, sera el array
drinks), podemos usar la variable especial {.} dentro del bucle para obtener el valor
actual:
var myTpl = new Ext.XTemplate(
'<tpl for="drinks">',
'<p>{#}. {.}</p>',
'</tpl>' );
myTpl.overwrite(panel.body, myData);

7.3.2. Condiciones
Para

introducir

condiciones

en

las

plantillas

se

utiliza

la

etiqueta

111

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

'<tpl

Programacin Web

if=condicion> plantilla </tpl>'.

Hemos de tener en cuenta que: si utilizamos las


comillas, deberemos escribirlas codificadas (&quot;), y que no existe el operador
else, si lo necesitamos deberemos de utilizar una condicin if adicional.
Ejemplos:
<tpl if="age > 1 && age < 10">Child</tpl>
<tpl if="age >= 10 && age < 18">Teenager</tpl>
<tpl if="name == &quot;Tommy&quot;">Hello Tommy!</tpl>

7.3.3. Visualizacin
Para renderizar el contenido de una plantilla sobre un panel (u otro elemento que lo
soporte,
como
veremos
ms
adelante),
podemos
usar
la
funcin
tpl.overwrite(elemento, datos) que ya hemos usado en los ejemplos anteriores.
O usar la propiedades tpl junto con data, de la forma:
MyApp.views.viewport = new Ext.Panel({
data: myData,
tpl: myTpl
});

7.3.4. Ms informacin
Para ms informacin sobre las plantillas (operaciones matemticas, ejecucin de cdigo
en lnea, variables especiales, funciones, etc.) consultar directamente la API de Sencha
Touch: http://docs.sencha.com/ext-js/4-0/#/api/Ext.XTemplate

7.4. Data Views


Los Data Views nos permiten mostrar datos de forma personalizada, mediante el uso de
plantillas y opciones de formato. Principalmente se utilizan para mostrar datos
provenientes de un Store y aplicarles formato utilizando las plantillas XTemplate, como
hemos visto en la seccin anterior. Adems tambin proporcionan mecanismos para
gestionar eventos como: click, doubleclick, mouseover, mouseout, etc., as como para
permitir seleccionar los elementos mostrados (por medio de un itemSelector).
Continuando con los ejemplos anteriores, vamos a crear un DataView para mostrar el
contenido de myStore por medio de plantilla myTpl:
var myDataView = new Ext.DataView({
store: myStore,
tpl: myTpl,
fullscreen: true
});

Esta vista de datos tenemos que aadirla a la seccin items de un panel para poder

112

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

visualizarla en nuestra aplicacin:


MyApp.views.viewport = new Ext.Panel({
items: [ myDataView ]
});

Para
ms
informacin
http://docs.sencha.com/touch/1-1/#!/api/Ext.DataView.

podis

consultar

7.5. Listados
Permiten mostrar datos en forma de listado a partir de una plantilla por defecto de tipo
lista. Estos datos se obtienen directamente de un store (Ext.data.Store) y se mostrarn
uno a uno en forma de listado segn la plantilla definida en itemTpl. Adems
incorpora funcionalidades para gestionar eventos como: itemtap, itemdoubletap,
containertap, etc.
Utilizarlo es muy simple, solo tenemos que definir el store que queremos utilizar, y la
plantilla para cada uno de los elementos con itemTpl:
var myList = new Ext.List({
store: myStore,
itemTpl: '{firstName} ' +
'{lastName}'
});

Es muy importante diferenciar itemTpl de la propiedad tpl que ya habamos visto


(en las que usbamos los XTemplate). En itemTpl se procesa cada elemento del listado
individualmente. Otra diferencia es que tenemos que utilizar como separador para la
concatenacin el smbolo de unin + y no la coma ,.
Una vez creado el listado solo nos faltar aadirlo a un panel para poder visualizarlo:
MyApp.views.viewport = new Ext.Panel({
items: [ myList ]
});

En el store debemos de utilizar la propiedad sorters para ordenar el listado, pues sino
nos aparecer desordenado. Por ejemplo, podramos indicar (en el store) que se ordene
por el apellido sorters: 'lastName'.
7.5.1. Obtener datos de la lista
Para obtener el almacn de datos asociado a un listado utilizamos la propiedad getStore:
var notesStore = myList.getStore();

Una vez obtenido ya podemos realizar operaciones sobre l como aadir, modificar o

113

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

eliminar algn registro.


7.5.2. Actualizar datos
Si modificamos el almacn de datos asociado con el listado tendremos que actualizarlo
para que se visualicen correctamente los nuevos datos en el listado. En primer lugar
llamaremos al mtodo sync() del Store para sincronizar los cambios. A continuacin, si
es necesario, ordenamos los datos (pues el registro se habr aadido al final). En el
ejemplo se ordenan de forma descendente por fecha. Por ltimo llamamos al mtodo
refresh() del listado para actualizar la vista.
notesStore.add( registro );
notesStore.sync();
notesStore.sort([{ property: 'date', direction: 'DESC'}]);
myList.refresh();

7.5.3. Agrupar elementos


Una propiedad muy til que nos ofrecen los listados es la posibilidad de agrupar los
elementos (como podemos ver en la imagen inferior). Para esto activaremos la propiedad
grouped: true y opcionalmente podremos indicar que se muestre una barra lateral de
navegacin indexBar: true.

Pero para que esta propiedad funcione dentro del store tenemos que indicar la forma de

114

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

agrupar los elementos. Tenemos dos opciones:


groupField: 'campo' - para agrupar por un campo (por ejemplo: elementos de
gnero masculino y femenino).
getGroupString: function(instance) {...} - para agrupar usando una funcin.
Esta opcin es mucho ms avanzada y nos permitir agrupar, por ejemplo, usando la
primera letra del apellido (como se muestra en la imagen de ejemplo).
Para obtener el resultado de la imagen de ejemplo anterior, el cdigo quedara:
var myStore = new Ext.data.Store({
model: 'Users',
sorters: 'apellido',
getGroupString: function(instance) {
return instance.get('apellido')[0];
}
});
var myList = new Ext.List({
store: myStore,
grouped : true,
indexBar: true,
itemTpl: '{nombre} {apellido}'
});

7.5.4. Acciones
Para aadir acciones al presionar sobre un elemento del listado tenemos varias opciones:
itemtap: permite realizar una accin al presionar sobre un elemento de la barra. Este
evento lo debemos definir dentro de la seccin listeners de nuestro Ext.List, de la
forma:
listeners: {
itemtap: function(record, index) { alert( "tap on" + index ); }
}

Donde el parmetro record representa el objeto sobre el que se ha pulsado. Este valor
lo podramos aprovechar para cargarlo directamente en un formulario o realizar
alguna operacin con l.
itemdoubletap: permite realizar una accin al presionar dos veces consecutivas
sobre un elemento. Este evento lo debemos definir dentro de la seccin listeners de
nuestro Ext.List, de la forma:
listeners: {
itemdoubletap: function(record, index){ alert("doubletap on "+index); }
}

Donde el parmetro record representa el objeto sobre el que se ha pulsado.


onItemDisclosure: Boolean / Funcin - esta propiedad admite varios valores. Si
le indicamos el valor booleano true simplemente aadir un icono con una flecha a
la derecha de cada elemento (como podemos ver en la imagen inferior).

115

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En lugar de un valor booleano, podemos indicarle una funcin. En este caso, adems
de aadirse el icono en cada elemento, tambin se ejecutar la funcin cada vez que se
presiones sobre dicho icono. Solo se capturar cuando se presione sobre el icono, no
sobre toda la barra (como en el caso de itemtap). Un ejemplo de cdigo:
onItemDisclosure: function (record) { alert( "item disclosure" ); }

Donde el parmetro record representa el objeto sobre el que se ha pulsado. En el


siguiente cdigo, al pulsar sobre un elemento de la lista se cargan los datos del
elemento pulsado en un formulario (como veremos ms adelante), y se cambia la vista
para visualizar ese panel.
onItemDisclosure: function( record )
{
MyApp.views.myFormPanel.load( record );
MyApp.views.viewport.setActiveItem(
'myFormPanel',
{ type: 'slide', direction: 'left' });
}

7.6. Formularios
En esta seccin vamos a ver como podemos cargar, guardar y validar los datos de un
formulario.
7.6.1. Cargar datos en un formulario
Para insertar datos en un formulario utilizamos el mtodo load( data ) de la clase
FormPanel. En el siguiente ejemplo se crea un formulario con dos campos llamados
title y text y a continuacin se cargan los datos del registro note.
var noteEditor = new Ext.form.FormPanel({
id: 'noteEditor',
items: [ {
xtype: 'textfield',
name: 'title',
label: 'Title',
required: true
}, {
xtype: 'textareafield',
name: 'narrative',
label: 'Narrative'
} ]
});

116

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

noteEditor.load( note );

El mtodo load( data ) recibe como parmetro una instancia de un modelo de datos
(ver seccin Data Model), del cual cargar solamente los campos cuyos nombre coincidan
con los establecidos en el formulario. En este formulario tenemos dos campos: name:
'title' y name: 'text', si cargamos una instancia de un modelo de datos como el descrito
a continuacin, solamente se cargaran los dos campos que coinciden.
Ext.regModel('Note', {
idProperty: 'id',
fields: [
{ name: 'id', type: 'int' },
{ name: 'date', type: 'date', dateFormat: 'c' },
{ name: 'title', type: 'string' },
{ name: 'text', type: 'string' }
]
});

En la seccin de "Data Model" ya hemos visto que podemos usar la funcin


Ext.ModelMgr.create(lista_valores, nombre_modelo) para crear instancias de
un modelo de datos. En el siguiente ejemplo se crea una instancia del modelo anterior y
se aade al formulario "noteEditor" que habamos definido anteriormente. En este caso, al
asignar los datos al formulario, solo se cargaran los campos title y text.
var note = Ext.ModelMgr.create({
id: 1,
date: new Date(),
title: 'titulo',
text: 'texto' },
'Note');
noteEditor.load( note );

A continuacin se incluye un ejemplo un poco ms avanzado: Creamos una barra de


herramientas a la que aadimos un botn con el texto Cargar datos. Para este botn
definimos su funcin handler, de forma que al pulsar el botn se crea una instancia del
modelo 'Note' y posteriormente se carga en el formulario 'noteEditor'.
var myToolbar = new Ext.Toolbar({
dock: 'top',
title: 'Mi barra',
items: [{
ui: 'action',
text: 'Cargar datos',
handler: function () {
var now = new Date();
var noteId = now.getTime();
// Identificador numrico nico
var note = Ext.ModelMgr.create({
id: noteId,
date: now,
title: 'titulo',
text: 'texto' },
'Note');
noteEditor.load( note );
} // End handler function
}] // End items section

117

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

});

7.6.2. Guardar los datos de un formulario


Para guardar los datos de un formulario en general tendremos que seguir cuatro pasos:
1. En primer lugar llamamos al mtodo getRecord() del formulario para obtener su
modelo de datos asociado, el cual devolver un objeto del tipo Ext.data.Model con
la definicin de los campos utilizados en el formulario, pero no sus valores.
2. A continuacin llamamos a la funcin updateRecord(objeto) del mismo formulario
para transferir los valores introducidos a la instancia del modelo que hemos obtenido
antes.
3. En tercer lugar tenemos que realizar el proceso de validacin de los datos (explicado
en el siguiente apartado).
4. Y por ltimo guardar los datos en el Store correspondiente. Si tenemos una instancia
del almacn de datos creada (ver seccin Data Store) podemos aadir los datos
llamando a su funcin add del Store, de la forma:
notesStore.add(currentNote);

En el siguiente cdigo de ejemplo se resumen los cuatro pasos que habra que seguir para
cargar los datos del formulario 'noteEditor' y guardarlos en el almacn 'notesStore'.
// Cargar el modelo de datos
var currentNote = noteEditor.getRecord();
// Actualizar el modelo con los datos del formulario
noteEditor.updateRecord(currentNote);
// Realizar validaciones
// (ver siguiente apartado)
// Guardar los datos
notesStore.add(currentNote);

Ms comnmente nuestro almacn estar asociado con algn elemento que nos permita
visualizar los datos (como un listado o un Data View, ver secciones correspondientes). Si
por ejemplo fuera un listado deberamos de obtener la instancia del almacn de datos
llamando a su mtodo getStore() y posteriormente aadir los datos que habamos
obtenido del formulario, de la forma:
var notesStore = notesList.getStore();
notesStore.add( currentNote );

Opcionalmente podemos comprobar si los datos a aadir estn repetidos. Para esto
tenemos que utilizar el mtodo findRecord() del Store (ver seccin Data Store).
var notesStore = notesList.getStore();
if( notesStore.findRecord('id', currentNote.data.id) === null)

118

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

{
notesStore.add( currentNote );
}

Para terminar con el ejemplo del listado, una vez aadidos los datos tendremos que
sincronizar su Store, ordenarlo (si fuese necesario) y por ltimo actualizar o refrescar la
vista del listado:
notesStore.sync();
notesStore.sort([{ property: 'date', direction: 'DESC'}]);
notesList.refresh();

7.6.3. Comprobar validaciones


Para comprobar las validaciones de un formulario lo tenemos que hacer de forma manual
llamando a la funcin validate() del modelo de datos asociado. Para esto tienen que
estar definidas estas validaciones en el modelo. Continuando con el ejemplo del modelo
de datos Note, vamos a aadir que los campos id, title y text sean requeridos:
Ext.regModel('Note', {
idProperty: 'id',
fields: [
{ name: 'id', type: 'int' },
{ name: 'date', type: 'date', dateFormat: 'c' },
{ name: 'title', type: 'string' },
{ name: 'text', type: 'string' }
],
validations: [
{ type: 'presence', field: 'id' },
{ type: 'presence', field: 'title',
message: 'Introduzca un ttulo para esta nota' },
{ type: 'presence', field: 'narrative',
message: 'Introduzca un texto para esta nota' }
]
});

Los pasos a seguir para realizar la validacin de un formulario son los siguientes:
1. Obtener el modelo de datos asociado a un formulario (getRecord()) y rellenarlo con
los datos introducidos por el usuario (updateRecord()).
2. Llamar a la funcin validate() del modelo de datos. Esta funcin comprueba que se
cumplan todas las validaciones que estn definidas en dicho modelo, devolviendo un
objeto del tipo Errors.
3. A continuacin usaremos la funcin isValid() del objeto Errors para comprobar si
ha habido algn error. Esta funcin devuelve un valor booleano indicando si existen
errores o no.
4. En caso de que existan errores tendremos que mostrar un aviso con los errores y no
realizar ninguna accin ms.
Dado que pueden haber varios errores (guardados en el array items del objeto
Errors), tenemos que iterar por los elementos de este array usando la funcin
Ext.each(array, funcion). Esta funcin recibe dos parmetros: el primero es

119

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

el array sobre el que va a iterar y el segundo la funcin que se llamar en cada


iteracin. Esta funcin recibe a su vez dos parmetros: el item de la iteracin
actual y el ndice de ese item en el array.
Para mostrar el aviso con los errores podemos usar un MessageBox (ver seccin
correspondiente).

A continuacin se incluye un ejemplo completo de la validacin de un formulario:


// Cargar el modelo de datos
var currentNote = noteEditor.getRecord();
// Actualizar el modelo con los datos del formulario
noteEditor.updateRecord(currentNote);
// Realizar validaciones
var errors = currentNote.validate();
if(!errors.isValid())
{
var message="";
Ext.each( errors.items, function(item, index) {
message += item.message + "<br/>";
});
Ext.Msg.alert("Validate", message, Ext.emptyFn);
return;

// Terminamos si hay errores

}
// Almacenar datos
notesStore.add(currentNote);

Tambin podramos haber creado un bucle para iterar entre los elementos del array de
errores, o haber llamado a la funcin errors.getByField('title')[0].message para
obtener directamente el mensaje de error de un campo en concreto.

7.7. Ms informacin
Podemos consultar principalmente tres fuentes de informacin cuando tengamos alguna
duda:
Los tutoriales y la seccin de FAQ en la pgina Web de Sencha Touch:
http://www.sencha.com/
La documentacin API Online:
http://docs.sencha.com/touch/1-1/
http://www.sencha.com/learn/touch/
Tambin disponible de forma local accediendo en la direccin /docs de tu SDK,
por ejemplo:
http://localhost/touch/docs/

Los foros en la pgina web de Sencha Touch:


http://www.sencha.com/forum/forumdisplay.php?56-Sencha-Touch-Forums

120

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Adems en la carpeta touch/examples podemos encontrar aplicaciones de ejemplo. Para


comprobar estos ejemplos en nuestro servidor podemos acceder a
http://localhost/touch/examples/, obteniendo:

En GitHub tambin podemos encontrar numerosas aplicaciones de ejemplo bien


documentadas,
estas
las
podemos
encontrar
en
la
direccin:
https://github.com/senchalearn/.

121

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

8. Ejercicios - Aspectos avanzados de Sencha Touch


En esta sesin vamos a continuar con los ejercicios anteriores del editor de notas.
Aadiremos los elementos necesarios para poder crear, editar, guardar y borrar notas, as
como visualizarlas en un listado.
Si necesitas ayuda puedes descargar la plantilla para los ejercicios sesion04-ejercicios.zip.

8.1. Ejercicio 1 - Modelo y Almacn de datos (0.8 puntos)


En este ejercicio vamos a crear el modelo de datos a utilizar y el almacn donde se van a
guardar.
Nuestro modelo de datos (con identificador 'modeloNotas') tendr cuatro campos: 'id' de
tipo 'int', 'date' de tipo 'date' y formato 'c', 'title' de tipo 'string' y 'text' de tipo 'string'.
Adems deberemos definir 'id' como identificador nico (ver seccin "Data Model") y las
siguientes validaciones: los campos 'id', 'title' y 'text' sern requeridos, y para los campos
'title' y 'text' modificaremos el mensaje de error por defecto, poniendo "Introduzca un
ttulo/texto".
A nuestro almacn de datos le pondremos como identificador 'storeNotas' y le
indicaremos que tiene que usar el modelo 'modeloNotas'. Como proxy vamos a usar el
almacenamiento en local, indicando como identificador 'misNotas-app-localstore'.
Adems indicaremos que se ordenen los datos de forma descendente (DESC) por fecha
(campo 'date'), y que se carguen los datos del repositorio al inicio (autoLoad: true).
De forma temporal y para poder ver los resultados vamos a insertar datos en el Store,
aadiendo las siguientes lneas al mismo:
data: [
{ id:
prueba' },
{ id:
prueba' },
{ id:
prueba' },
{ id:
prueba' }
]

1, date: new Date(), title: 'Test 1', text: 'texto de


2, date: new Date(), title: 'Test 2', text: 'texto de
3, date: new Date(), title: 'Test 3', text: 'texto de
4, date: new Date(), title: 'Test 4', text: 'texto de

8.2. Ejercicio 2 - Listado (0.6 puntos)


En este ejercicio vamos a crear el listado donde se visualizarn los datos. Le pondremos
como identificador 'panelLista' y le diremos que utilice el store 'storeNotas' que hemos
definido previamente.
En su seccin itemTpl indicaremos que muestre el campo {title} dentro de una capa

122

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

con el estilo "list-item-title", y que el campo {text} lo muestre a continuacin en otra


capa que use el estilo "list-item-text".
Este listado ('panelLista') lo tendremos que aadir a nuestro panel 'panelContenedorLista'
en su seccin items para poder visualizarlo.
Ahora tenemos que aadir esos estilos al fichero app.css. Para ambas clases
('list-item-title' y 'list-item-text') definiremos los mismos estilos (ver cdigo siguiente),
salvo para el "list-item-text" que adems tendr el texto en color gris.
.list-item-title { /* Igual para: list-item-text */
float:left;
width:100%;
font-size:80%;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
/* Para list-item-text aadimos 'color: gray;' */
}

8.3. Ejercicio 3 - Crear y Editar notas (0.8 puntos)


Vamos a modificar la funcin handler del botn "Nueva nota" para que al pulsarlo,
antes de realizar la transicin, cree una nueva nota y la asigne al formulario. Para esto
vamos a aadir una llamada a la funcin crearNuevaNota() (la cual crearemos de forma
separada).
En la funcin crearNuevaNota() en primer lugar nos guardaremos la fecha actual var
now = new Date();, y a continuacin obtendremos el identificador nico del registro a
crear var noteID = now.getTime(); (con esta funcin transformamos la fecha en
milisegundos, con lo que obtenemos un nmero que no se repite que podemos usar como
ID). A continuacin creamos un registro del modelo 'modeloNotas' y lo cargamos en
nuestro formulario (panelFormulario.load( note );).
Por ltimo vamos a aadir la funcionalidad de editar las notas creadas. Para esto vamos
hasta el 'panelLista', y definimos su funcin onItemDisclosure. Esta funcin recoge un
parmetro (record) que tenemos que cargar en el 'panelFormulario'
(panelFormulario.load( record );). A continuacin realizaremos una transicin de
tipo 'slide' hacia la izquierda y con una duracin de 1 segundo, para mostrar el
'panelFormulario'.

8.4. Ejercicio 4 - Guardar y Borrar notas (0.8 puntos)


En este ltimo ejercicio vamos a aadir las acciones de guardar y borrar nota. En las
funciones handler de los botones "Guardar" y "Borrar" aadiremos llamadas a las
funciones guardarNota() y borrarNota() respectivamente. Las llamadas a estas
funciones las deberemos de incluir antes de realizar la transicin. A continuacin
definiremos las acciones a realizar en estas funciones (que estarn definidas de forma
123

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

separada).
En la funcin guardarNota() realizaremos los siguientes pasos:
1. En primer lugar tendremos que cargar los datos introducidos en el formulario
(usaremos la funcin getRecord() sobre la variable que contiene el formulario), y a
continuacin actualizaremos la instancia del formulario (ver seccin "Guardar los
datos de un formulario").
2. En segundo lugar comprobaremos si hay algn error de validacin y mostraremos los
errores (ver apartado "Comprobar validaciones" de la seccin "Formularios").
3. Una vez validado el registro obtenido procederemos a guardar los datos. Obtenemos
el Store usado por el listado y aadimos el registro solo si este no est repetido
(funcin findRecord()).
4. Por ltimo actualizamos el Store (sync()), lo reordenamos por fecha y refrescamos el
listado (refresh()).
La funcin borrarNota() es ms sencilla:
1. Asignamos a variables el registro actual del formulario (getRecord()) y el Store
usado por el listado (getStore()).
2. A continuacin comprobaremos si existe el registro actual en el store (usando su "id")
y si es as lo eliminaremos (ver apartado "Eliminar registros" de la seccin "Data
Store").
3. Por ltimo actualizaremos los datos del Store (sync()) y refrescamos el listado
(refresh()).

124

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

9. Introduccin a jQuery Mobile


En esta seccin introduciremos el framework jQuery Mobile y veremos como podemos
crear una aplicacin web para mviles de forma muy rpida y sencilla.

9.1. Qu es jQuery Mobile?


jQuery Mobile es un framework de interfaz grfica especialmente diseado para el
desarrollo de aplicaciones web para mviles que pretende unificar el diseo de interfaces
de usuario para la mayora de dispositivos mviles del mercado. Como su propio nombre
indica, jQuery Mobile tiene como base el ms que slido framework javascript jQuery.
Adems, es un framework muy ligero, algo totalmente necesario por las propias
caractersticas de los dispositivos mviles y sus capacidades de conexin. Por otro lado,
el diseo es fcilmente modificable.
jQuery Mobile est apoyado en estos momentos por empresas tan importantes como
Mozilla Corporation, Palm, Blackberry, Nokia y Adobe entre otras, y es que estas
empresas no quieren seguir perdiendo mercado que dispositivos como Android y iPhone
con sus aplicaciones nativas les ha hecho perder en los ltimos tiempos.
El objetivo principal de este framework es conseguir una misma sensacin de navegacin
por parte del usuario final en la mayora de los dispositivos mviles. Por otro lado, si
pensamos en el desarrollador, jQuery Mobile pretende que ste se centre en las
caractersticas del producto y no tanto en el dispositivo mvil al que va dirigido tomando
como suya la frase "write less, do more" (escribe menos, consigue ms).

125

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Dispositivos funcionando con jQuery Mobile


9.1.1. Caractersticas de jQuery Mobile
Las principales caractersticas de jQuery Mobile son las siguientes:
Basado en el ncleo de jQuery
Compatible con la mayora de los dispositivos y navegadores
Tamao reducido, alrededor de los 20k
Uso de HTML5 y sus caractersticas para evitar tener que escribir scripts
Mejora progresiva, introduciendo todas las nuevas caractersticas a la gran mayora de
dispositivos
Accesibilidad, asegurando que las aplicaciones implementadas con jQuery Mobile
funcionar correctamente en los lectores de pantalla (como VoiceOver en iOS)
Se soportan la mayora de los eventos de ratn y de contacto
Sencilla modificacin del diseo base
9.1.2. Soporte de jQuery Mobile
Siguiente con la idea de abarcar el mayor nmero de dispositivos posibles, desde jQuery
Mobile se ha dividido en 3 grados el soporte que se da a los diferentes dispositivos con lo
que tendremos el grado A, B y C. El grado A indica aquellos dispositivos que soportan
todas las caractersticas de jQuery Mobile entre las que destaca la navegacin entre
pginas web mediante AJAX y las transiciones entre las mismas. El grado B representa
aquellos dispositivos que no soportan la caracterstica de navegacin con AJAX. Y por
ltimo, el grado C que representa los dispositivos en los que nicamente se garantiza el

126

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

comportamiento bsico de las aplicaciones web creadas con jQuery Mobile.


La siguiente tabla representa aquellos dispositivos y navegadores y el grado de
funcionamiento que jQuery Mobile garantiza en stos.
Grado A

Grado B

Grado C

Apple iOS 3.2-5.1 beta

Blackberry 5.0

Blackberry 4.x

Android 2.1-2.3

Opera Mini (5.0-6.5)

Windows Mobile

Android 3.1 Honeycomb

Nokia Symbian^3

El resto de
navegadores

dispositivos

Windows Phone 7-7.5


Blackberry 6.0
Blackberry 7
Blackberry Playbook (1.0-2.0)
Palm WebOS (1.4-2.0)
Palm WebOS 3.0
Firebox Mobile (10 Beta)
Chrome for Android (Beta)
Skyfire 4.1
Opera Mobile 11.5-12
Meego 1.2
Samsung bada 2.0
UC Browser
Kindle 3 and Fire
Nook Color 1.4.1
Chrome Desktop 11-19
Safari Desktop 4-5
Firefox Desktop Explorer 4-13
Internet Explorer 7-9
Opera Desktop 10-12

9.1.3. Cmo funciona jQuery Mobile?

127

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

El funcionamiento de jQuery Mobile es muy sencillo, ya que el programador


simplemente debe encargarse de crear pginas con formato HTML (con unas pequeas
modificaciones) y jQuery Mobile ser el encargado de realizar una serie de
transformaciones en los elementos del DOM de esas pginas para que la interfaz de
usuario sea lo ms atractiva posible para los clientes de dispositivos mviles.
Estas transformaciones se realizan cuando el navegador recibe el contenido del
documento HTML solicitado y siempre antes de que sea mostrado al usuario.

9.2. Pginas en jQuery Mobile


9.2.1. Anatoma de una pgina
En jQuery Mobile tenemos dos posibilidades para organizar una aplicacin web. Por un
lado podemos tener pginas individuales y utilizar los tpicos enlaces para navegar entre
las diferentes pginas de la aplicacin, pero por otro lado, jQuery Mobile tambin nos da
la posibilidad de tener varias pginas web en un slo documento html. De esta forma,
nuestra pgina tardar un poco ms en cargar pero la navegacin por parte del usuario
final ser ms amena.
Pero empecemos creando una pgina bsica con jQuery Mobile analizando de esta forma
la estructura. En primer lugar, debemos empezar especificando el doctype de HTML5.
No te preocupes si tu dispositivo no soporta HTML5 porque directamente ignorar esta
directiva. Lo siguiente que debemos hacer es referenciar a las librera tanto de jQuery
como de jQuery Mobile en la etiqueta head as como al archivo css de jQuery Mobile. Es
aconsejable referenciar estos archivos en algn CDN para conseguir una mejor
experiencia por parte del usuario, ya que si estos archivos ya han sido cacheados al
acceder a otra aplicacin implementada en jQuery Mobile, el acceso a nuestra aplicacin
ser mucho ms rpida. Con estos datos, nuestra pgina web podra ser as:
<!DOCTYPE html>
<html>
<head>
<title>Ttulo de la pgina</title>
<meta charset="utf-8"/>
<meta name="viewport" content="width=device-width,
initial-scale=1"/>
<link rel="stylesheet"
href="http://code.jquery.com/mobile/1.1.1/jquery.mobile-1.1.1.min.css" />
<script type="text/javascript"
src="http://code.jquery.com/jquery-1.7.1.min.js"></script>
<script type="text/javascript"
src="http://code.jquery.com/mobile/1.1.1/jquery.mobile-1.1.1.min.js"></script>
</head>
<body>
...aqu ira el contenido...
</body>
</html>

128

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Quizs te llame la atencin la utilizacin de la etiqueta <meta name="viewport"


content="width=device-width, initial-scale=1"/>. Con esta etiqueta, muchos
navegadores ajustan el nivel de zoom de la pgina al tamao correcto.
Si cargsemos esta pgina en un mvil, notaramos como jQuery Mobile se encarga
automticamente de hacer desaparecer la barra de la direccin url para aprovechar al
mximo el espacio disponible en la pantalla del dispositivo con lo que veramos la
siguiente pgina.

Aplicacin web con jQuery Mobile


Pero sigamos creando la base de nuestra aplicacin web para mviles. En jQuery Mobile
cada pgina de nuestra aplicacin debe estar en un elemento HTML de tipo div al cual le
tenemos que pasar un atributo llamado data-role indicndole que su valor ser page.
<div data-role="page">
....
</div>

Dentro de esta capa se puede utilizar cualquier elemento HTML vlido, sin embargo lo
ms habitual en nuestras aplicaciones con jQuery Mobile ser que utilicemos otras capas
con el atributo data-role con los valores header, content y footer.

129

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<div data-role="page">
<div data-role="header">Ttulo</div>
<div data-role="content">Contenido</div>
<div data-role="footer">Pie de pgina</div>
</div>

Aplicacin web con jQuery Mobile


Hasta el momento, en nuestro documento html nicamente hemos creado una pgina web,
pero tal y como comentbamos anteriormente, podemos tener ms de una pgina web en
un nico documento html para que la navegacin entre las pginas de nuestra aplicacin
sea ms eficiente. Si queremos hacer esto, en cada bloque div con el atributo data-role
a page debemos aadir el atributo id, que deber tener un valor nico en cada documento
html. Posteriormente, los enlaces entre las pginas se debe hacer especificando dicho
identificador precedido del smbolo # de la siguiente forma <a href="#acercade">.
<body>
<!-- Inicio de la primera pgina -->
<div data-role="page" id="home">
<div data-role="header">
<h1>Home</h1>
</div><!-- /header -->
<div data-role="content">
<p>

130

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Esta es mi primera aplicacin con jQuery Mobile


y ha sido creada por <a href="#author">Fran
Garca</a>
</p>
</div><!-- /content -->
<div data-role="footer">
<h4>Pie de pgina</h4>
</div><!-- /footer -->
</div><!-- /page -->
<!-- Start of second page -->
<div data-role="page" id="author">
<div data-role="header">
<h1>Fran Garca</h1>
</div><!-- /header -->
<div data-role="content">
<p>Mi nombre es Fran Garca y soy programador de
aplicaciones web.</p>
<p><a href="#home">Volver al inicio</a></p>
</div><!-- /content -->
<div data-role="footer">
<h4>Pie de pgina</h4>
</div><!-- /footer -->
</div><!-- /page -->
</body>

Varias pginas en un slo documento HTML


Cuando en un documento html coexisten ms de un elemento div con el atributo
data-role a page, jQuery Mobile mostrar nicamente la primera pgina encontrada. Si
ahora probamos nuestra aplicacin con un dispositivo mvil, comprobaremos que si
hacemos clic sobre el enlace del autor de la aplicacin, sta se muestra mediante una
transicin animada.
Hay que tener en cuenta que con jQuery Mobile no es posible enlazar directamente a una
"pgina" con un enlace del tipo <a href="index.html#foo">. Esto es debido a que
jQuery Mobile intentar buscar una "pgina" con un identificador #foo en lugar del
comportamiento nativo de hacer scroll directo hasta el ancla en cuestin.
131

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Comentar tambin que todos los elementos vistos hasta el momento son opcionales, sin
embargo, puede ser una buena forma de estructurar nuestra aplicacin web.
9.2.2. Ttulos de las pginas
Cuando en una pgina desarrollada con jQuery Mobile cargamos una pgina, hacemos
clic en un enlace o envamos un formulario, jQuery Mobile utiliza Ajax para cargar el
contenido de la pgina destino. El problema de esta forma de trabajar es que el ttulo de la
pgina siempre ser el de la primera pgina cargada. Sin embargo, jQuery Mobile se
encarga de recoger el ttulo de la nueva pgina cargada y sustituirlo por la pgina que ha
realizado la llamada Ajax.
Algo parecido sucede con los documentos con ms de una pgina, en los cuales, el ttulo
de la misma se comparte en todas ellas. Sin embargo, jQuery Mobile nos permite cambiar
este ttulo aadiendo un nuevo atributo en la pgina en cuestin llamado data-title.
<div data-role="page" id="foo" data-title="Page Foo">
...
</div>

9.2.3. Enlaces entre pginas


jQuery Mobile est especialmente diseado para funcionar de forma muy sencilla con una
serie de convenciones a la hora de enlazar pginas y lo mejor es que esa convencin no
supone ningn cambio en la forma habitual de trabajar y ser jQuery Mobile el encargado
de gestionar esas llamadas a otras pginas (utilizando Ajax siempre que sea posible) para
generar el comportamiento deseado.
En algunos casos no es posible realizar esta llamada Ajax como por ejemplo en aquellos
enlaces a otros dominios o bien cuando se especifique directamente en los atributos del
enlace (esto lo veremos ms adelante). En estos casos, se realizar una peticin http
normal y corriente.
La idea de este modelo es permitir a los desarrolladores crear aplicaciones web con
jQuery Mobile sin ninguna configuracin especial pero que al mismo tiempo parezcan
aplicaciones nativas.
9.2.3.1. Comportamiento bsico de los enlaces: Ajax

Para permitir las transiciones entre las pginas, todos los enlaces que apunten a una
pgina externa, se cargarn va Ajax y para que esto sea lo menos intrusivo posible,
jQuery Mobile recoge la pgina destino, la procesa y la aade al DOM de la pgina
actual. Mientras esto se est realizando, se mostrar la tpica imagen que indica que el
contenido de la pgina se est cargando en estos momentos. En caso de que la nueva
pgina, se cargue correctamente, sta se muestra mediante una transicin.
En caso de que en la peticin Ajax se produzca un error, jQuery Mobile mostrar un
132

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

pequeo mensaje de error que desaparecer a los pocos segundos.

Pgina de error
9.2.3.2. Enlaces sin utilizar Ajax

En algunas ocasiones, jQuery Mobile no cargar los enlaces de nuestras aplicaciones


utilizando Ajax. Estos casos son los siguientes:
Enlaces que apunten a dominios externos
Enlaces que tengan el atributo rel="external"
Enlaces que tengan el atributo data-ajax="false"
Enlaces que utilicen el atributo target
En estos casos, las pginas no se cargarn con Ajax y por lo tanto la pgina se recargar
por completo y por supuesto, sin animacin. Es necesario sin embargo diferenciar que el
atributo rel="external" se debe utilizar cuando se enlaza a otro sitio o dominio,
mientras que el atributo data-ajax="false" se utilizar en aquellos casos en que por
cualquier motivo necesitemos cargar una pgina en nuestra aplicacin sin utilizar Ajax.
9.2.3.3. Enlaces en un documento multi-pgina

Como hemos comentado anteriormente, un nico documento HTML puede contener una
o varias pginas nicamente especificando diversos elemento de tipo div con el atributo
data-role="page" y un valor diferente para cada pgina del atributo id. Esto hace que
podamos tener una aplicacin completa en un nico documento HTML. Cuando un
usuario acceda a nuestra aplicacin, jQuery Mobile mostrar la primera pgina que
encuentre.
Si un enlace de un documento multi-pgina apunta a un ancla, como por ejemplo #foo,
jQuery Mobile buscar un elemento de tipo div con el atributo id="foo". En caso de que
lo encuentre, se mostrar el contenido de esa pgina mostrando anteriormente una
transicin. Del mismo modo podemos tener tambin enlaces a otros documentos HTML y
la nica diferencia en este caso es que jQuery Mobile mostrar una imagen al usuario
indicando que la pgina se est cargando. En ambos casos, la url se actualizar de tal

133

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

forma que el usuario pueda utilizar el botn para volver atrs, enlazar directamente un
determinado contenido o bien utilizar la opcin de favoritos del navegador.
Aviso:
Es importante saber que si estamos enlazando desde una pgina que fue cargada va AJAX a un
documento HTML con varias pginas, es necesario aadir el atributo rel="external" o
data-ajax="false". Esto indicar a jQuery Mobile que la pgina debe ser cargada por
completo. Si no hacemos esto, el usuario experimentar problemas a la hora de navegar por
nuestra aplicacin, especialmente si utiliza el botn para volver atrs.
<a href="multipagina.html" rel="external">Multi-pgina</a>

9.2.3.4. Botn Atrs

En jQuery Mobile implementar la posibilidad de que el usuario pueda volver atrs en


nuestra aplicacin es muy sencillo y podemos conseguirlo simplemente especificando el
atributo data-rel="back" en un enlace. jQuery Mobile se encargar de obviar el valor
del atributo href.
Hay que tener en cuenta tambin que si nicamente se desea que se realice una transicin
que simule una vuelta atrs podemos utilizar el atributo data-direction="reverse".
Aviso:
Hay que tener cuidado con el atributo data-rel="back" porque si nuestra aplicacin no es
secuencial y podemos saltar a diversas partes de la misma desde un mismo punto, esta
caracterstica que implementa el botn atrs automticamente puede darnos problemas.

9.2.4. Transiciones entre pginas


Actualmente, jQuery Mobile permite hasta seis tipos de transiciones en nuestras
aplicaciones. Estas transiciones estn implementadas mediante CSS y se pueden aplicar a
cualquier objeto o pgina. Por defecto, siempre se aplica la transicin que muestra el
nuevo contenido de derecha a izquierda.
Para especificar una transicin diferente, se puede aadir el atributo data-transition al
enlace en cuestin. Los posibles valores de este atributo son los siguientes:
slide, se mostrar el nuevo contenido con una transicin de derecha a izquierda
slideup, se mostrar el nuevo contenido con una transicin de arriba a abajo
slidedown, se mostrar el nuevo contenido con una transicin de abajo a arriba
pop, se mostrar el nuevo contenido con una transicin que empieza desde el centro
de la pgina
fade, se mostrar el nuevo contenido con una transicin que se mostrar
desvaneciendo al contenido antiguo y mostrando poco a poco el nuevo
flip, se mostrar el nuevo contenido con una transicin que simula la apertura de una

134

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

puerta. Mencionar que esta transicin no funciona en la mayora de las versiones de


Android porque carece de transformaciones 3D con CSS.
Comentar por ltimo que tambin es posible forzar una transicin de "vuelta atrs"
especificando el atributo data-direction="reverse".
9.2.5. Dilogos
jQuery Mobile permite simular la creacin de cuadros de dilogo en nuestras
aplicaciones.
9.2.5.1. Creando cuadros de dilogos

Cualquier pgina de nuestras aplicaciones con jQuery Mobile pueden ser mostradas como
un cuadro de dilogo simplemente aadiendo el atributo data-rel="dialog" al enlace
que muestra la pgina destino. Cuando se detecta este atributo, jQuery Mobile se encarga
de poner unos bordes redondeados a la nueva pgina, crear automticamente unos
mrgenes alrededor de la pgina y poner un fondo oscuro para que parezca que la nueva
pgina est suspendida por encima de la pgina que lo carga.
<a href="foo.html" data-rel="dialog">
Abrir cuadro de dilogo
</a>

Cuadro de dilogo
9.2.5.2. Transiciones

Por defecto, el dialogo se abre con una transicin del tipo pop, pero como en todas las
pginas, se puede especificar cualquier otra transicin simplemente aadiendo el atributo

135

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

y especificar cualquiera de los valores que veamos anteriormente.


Para que simular lo ms posible los efectos de los cuadros de dilogo, se aconseja utilizar
las transiciones pop, slideup o flip.
data-transition

<a href="foo.html" data-rel="dialog" data-transition="pop">


Abrir cuadro de dilogo
</a>

9.2.5.3. Cerrando cuadros de dilogos

Al hacer clic en cualquier enlace dentro de un cuadro de dilogo, jQuery Mobile se


encargar automticamente de cerrarlo y mostrar la transicin correcta. Sin embargo, si
queremos generar el tpico botn de Cerrar en un cuadro de dilogo, simplemente
debemos aadir el atributo data-rel="back".
9.2.5.4. Historial y botn Atrs

Habitualmente, los cuadros de dilogo se generan en el contexto de otras pginas. jQuery


Mobile se encarga de no incluir estos cuadros de dilogo en el historial de navegacin de
nuestro navegador. Del mismo modo, cuando un usuario haga clic en el botn Atrs del
navegador, no ser posible llegar de nuevo a un cuadro de dilogo, con lo que no tenemos
preocuparnos en absoluto por este tema.
9.2.6. Precarga y cach de pginas
A continuacin vamos a ver algunas tcnicas presentes en jQuery Mobile para mejorar la
experiencia del usuario a la hora de navegar por nuestra aplicacin.
9.2.6.1. Precarga de pginas

Si en tu aplicacin utilizas un documento html con una sola pgina web, pero sin
embargo, prefieres cargar el contenido de determinadas pginas sin mostrar la tpica
imagen de "Cargando...", podemos hacer una precarga de estas pginas simplemente
aadiendo el atributo data-prefetch a cualquier enlace que queremos precargar. jQuery
Mobile se encargar de cargar el contenido de esta pgina enlazada sin que el usuario vea
nada. Este podra ser un ejemplo:
<a href="enlaceprecargado.html" data-prefetch>Enlace precargado</a>

As es como funciona internamente jQuery Mobile en estas precargas. Una vez la pgina
principal se ha cargado por completo, jQuery Mobile buscar entre todos los enlaces
aquellos que tengan el atributo data-prefetch para automticamente cargar el contenido
de esos enlaces. De esta forma, cuando el usuario haga clic en estos enlaces, la carga del
contenido se har mucho ms rpida que se hara si no hubiramos hecho esta precarga.
Adems, la imagen de "Cargando..." ya no volver a aparecer salvo que por cualquier
motivo, el contenido de la pgina enlazada todava no se haya podido cargar en nuestra

136

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

aplicacin.
Es importante saber que estas precargas realizarn una serie de peticiones que en
ocasiones nunca se utilizarn, con lo que debemos slo utilizar esta precarga en
determinadas situaciones y cuando sepamos con un alto grado de certeza que el usuario
har clic en ese enlace.
9.2.6.2. Cach de pginas

Cuando se realizan las transiciones entre las diferentes pginas de nuestra aplicacin,
debemos tener en cuenta que ambas pginas deben estar cargadas en el DOM y que
conforme vamos navegando por las mismas, ms pginas se irn aadiendo a este DOM,
lo que en versiones anteriores de jQuery Mobile provocaba en ocasiones que el
rendimiento de la aplicacin bajara o que incluso el navegador se cerrara
inesperadamente.
Para solucionar este problema, jQuery Mobile se encarga de gestionar las pginas
almacenadas en el DOM y lo hace aadiendo un flag a estas pginas una vez ya hemos
accedido a otra pgina del DOM. En caso de que volvamos a una pgina que ya haya sido
eliminada del DOM previamente, el navegador intentar cargar la pgina de su propia
cach o ser de nuevo solicitada al servidor. Esto sucede nicamente con aquellas pginas
que se cargan va Ajax y no con los documentos html multi-pginas.
Sin embargo, jQuery Mobile tambin especifica una forma de gestionar nosotros mismos
la cach de determinadas pginas de nuestra aplicacin que consideremos interesantes.
Esta gestin de la cach del DOM, supone que nosotros somos quienes deberemos
encargarnos de controlar que el tamao del mismo no exceda unos determinados lmites.
Podemos hacerlo de dos formas. Por un lado aplicando esta gestin de la cach a toda
nuestra aplicacin.
$.mobile.page.prototype.options.domCache = true;

O bien especificarlo nicamente en determinadas pginas mediante el atributo


data-dom-cache="true".
<a href="foo/bar/baz" data-dom-cache="true">link text</a>

9.2.7. Estilo de los componentes jQuery Mobile


jQuery Mobile dispone de un sistema muy robusto y sencillo para estilizar nuestra
aplicacin de varias formas. Cada componente de jQuery Mobile tiene la posibilidad de
ser estilizado de una forma diferente. Para aplicar estos estilos, estos componentes pueden
aadir el atributo data-theme y puede tomar los valores, a, b, c, d o e para elegir
cualquiera de los cinco temas de los que dispone actualmente jQuery Mobile. Cada uno
de estos temas, utiliza una serie de combinaciones de colores y formas diferentes. Por
defecto, jQuery Mobile utiliza una combinacin de estos temas tal y como vemos en las

137

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

siguientes imgenes.
Tema por defecto

Tema por defecto


Tema A

Tema A
Tema B

Tema B

138

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Tema C

Tema C
Tema D

Tema D
Tema E

Tema E

9.3. Barras de herramientas

139

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Las barras de herramientas son utilizadas habitualmente en las cabeceras y los pies de
nuestras aplicaciones en cualquier aplicacin web mvil. Por este motivo, jQuery Mobile
nos ofrece una serie de componentes ya preparados para ser utilizados en nuestras
aplicaciones.
9.3.1. Tipos de barras de herramientas
En una aplicacin jQuery Mobile estndar, veremos dos tipos de barras de herramientas:
las cabeceras (headers) y los pies de pgina (footers):
La barra de herramientas de la cabecera se utiliza para indicar el ttulo de la pgina
actual, casi siempre es lo primero que se muestra en la aplicacin y es aconsejable que
como mucho tenga dos botones, uno a la izquierda del ttulo y otro a la derecha.
La barra de herramientas del pie de pgina es habitualmente el ltimo elemento en
cada pgina y los desarrolladores la pueden utilizar de diversas formas, aunque lo
normal es que haya una combinacin entre texto y botones.
Tambin es muy habitual que las aplicaciones realizadas con jQuery Mobile utilicen una
navegacin horizontal que suele estar incluida en la cabecera y/o en el pie de pgina. Para
ello, jQuery Mobile introduce una barra de navegacin predeterminada que convierte una
lista desordenada de enlaces en una barra horizontal del siguiente estilo:

Barra de navegacin
Para facilitarnos an ms el trabajo con estas barras de herramientas, jQuery Mobile
facilita incluso el posicionamiento de stas en una aplicacin. Por defecto, estas barras se
colocan una detrs de la otra del mismo modo en el que se definen en nuestro documento
html en lo que se conoce como posicin inline.
Sin embargo, en ocasiones deseamos que una determinada barra de herramientas est
siempre visible en nuestra aplicacin para facilitar su uso por parte del usuario en lo que
se conoce como posicin fixed. La barra de herramientas aparecer en la misma posicin
como si hubiera sido definida de tipo inline, pero en cuanto el usuario haga scroll en la
aplicacin, la barra de herramientas se desplazar para ocupar una posicin visible en la
aplicacin.
Incluso estas barras de herramientas desaparecern y aparecern de nuestra aplicacin con
cada contacto que el usuario haga en el dispositivo mvil. Para indicar que una barra de
herramientas debe tener este tipo de posicin podemos poner el atributo
data-position="fixed".
Por otro lado, jQuery Mobile tambin dispone del modo a pantalla completa para las
barras de herramientas. Bsicamente funcionan de la misma forma que la posicin fixed,
salvo que sta ya no se muestra al inicio o al final de la pgina y slo se muestra cuando

140

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

el usuario hace clic sobre la pgina. Este tipo de posicionamiento es muy til en
aplicaciones donde se muestren fotos o vdeos, en los cuales queremos cargar el
contenido a pantalla completa y esta barra de herramientas nicamente se mostrar
cuando el usuario toque la pantalla.
Para habilitar esta caracterstica en nuestras aplicaciones debemos especificar el atributo
data-fullscreen="true" al elemento div que contiene el atributo data-role="page"
y adems, debemos indicar tambin el atributo data-position="fixed" en la cabecera y
en el pie de la pgina.
9.3.2. Cabeceras
Como comentbamos anteriormente, la cabecera se sita al inicio de las pginas y
habitualmente contiene un ttulo y opcionalmente puede tener hasta dos botones a los
lados del ttulo. Para el ttulo de la cabecera habitualmente se utiliza el encabezado <h1>,
aunque tambin posible utilizar cualquiera de los otros encabezados (h1-h6). Por ejemplo,
un documento html multi-pgina puede tener un ttulo de tipo h1 en la primera pgina y
un ttulo h2 en la segunda, sin embargo, por defecto, jQuery Mobile los mostrar con el
mismo estilo por motivos de consistencia visual. Comentar tambin que por defecto, las
cabeceras utilizan el estilo a (fondo negro y letras en blanco).
9.3.2.1. Botones

En la configuracin estndar de las cabeceras se ha dejado un espacio para aadir hasta


dos botones a ambos lados del ttulo y habitualmente se utilizan enlaces como botones.
jQuery Mobile localiza el primero de estos enlaces y lo coloca automticamente a la
izquierda del ttulo y el segundo enlace (en caso de que lo haya), a la derecha del ttulo.
<div data-role="header" data-position="inline">
<a href="index.html" data-icon="delete">Cancel</a>
<h1>Edit Contact</h1>
<a href="index.html" data-icon="check">Save</a>
</div>

Cabecera con botones


Los botones automticamente adoptan el mismo estilo que la barra que los contiene, pero
tal y como hemos visto antes, podemos modificar este diseo para mostrar otro diseo a
los usuarios.
<div data-role="header" data-position="inline">
<a href="index.html" data-icon="delete">Cancel</a>
<h1>Edit Contact</h1>
<a href="index.html" data-icon="check" data-theme="b">Save</a>
</div>

141

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Cabecera con botones


Pero, qu pasa si queremos controlar la posicin donde se pinta el botn? Pues que la
gente de jQuery Mobile ya ha pensado en esto y simplemente aadiendo el atributo class
con los valores ui-btn-left o ui-btn-right al enlace en cuestin podremos indicar
donde queremos que aparezca el botn.
<div data-role="header" data-position="inline">
<h1>Page Title</h1>
<a href="index.html" data-icon="gear"
class="ui-btn-right">Options</a>
</div>

Controlando la posicin de los botones


Adems de estos botones, jQuery Mobile tambin pone a disposicin de los
desarrolladores la posibilidad de que automticamente se cree un botn para volver atrs
en las pginas de nuestras aplicaciones. Sin embargo, por defecto esta opcin est
desactivada. Para activarla nicamente debemos especificar en aquellas pginas donde
queramos insertar automticamente este botn el atributo data-add-back-btn="true"
Esto colocar un botn a la izquierda del ttulo que permitir al usuario volver atrs. Sin
embargo, este texto aparecer en ingls, cosa que no siempre ser lo deseado. Vamos a
poder
modificar
el
texto
que
aparece
indicando
el
atributo
data-back-btn-text="Atrs" en la pgina en cuestin. De igual forma tambin
podremos modificar el tema por defecto de este botn Atrs con el atributo
data-back-btn-theme="e".
Pero adems de esta forma, tambin podemos crear nosotros mismos nuestros botones
para volver atrs simplemente especificando el atributo data-rel="back" a un enlace en
cuestin. Adems, recuerda que tambin tenemos la posibilidad de mostrar una transicin
inversa con el atributo data-direction="reverse".
9.3.3. Pies de pgina
Ahora que ya conocemos como podemos modificar el comportamiento de las cabeceras
con jQuery Mobile, pasemos a ver en profundidad los pies de pgina, que bsicamente
tienen la misma estructura que las cabeceras con la salvedad, claro est, del atributo
data-role="footer".
<div

data-role="footer">
<h4>Pie de pgina</h4>
</div>

142

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Estructuralmente, los pies de pginas son muy parecidos a las cabeceras, con la salvedad
que en los pies de pgina, jQuery Mobile no aade automticamente esos botones que
veamos anteriormente a ambos lados del ttulo, con lo que si queremos mostrar botones,
los vamos a tener que pintar nosotros mismos.
Cualquier enlace vlido aadido en el pie de pgina podemos convertirlo
automticamente en un botn en nuestra aplicacin. Para ello debemos utilizar el atributo
data-role="button". Por defecto, jQuery Mobile no aade ningn tipo de espaciado
entre los botones y los laterales del navegador, con lo que si queremos que no aparezcan
demasiado pegados a esos laterales, podemos utilizar el atributo class="ui-bar".
<div data-role="footer" class="ui-bar">
<a href="index.html" data-role="button"
data-icon="delete">Remove</a>
<a href="index.html" data-role="button" data-icon="plus">Add</a>
<a href="index.html" data-role="button" data-icon="arrow-u">Up</a>
<a href="index.html" data-role="button"
data-icon="arrow-d">Down</a>
</div>

Pie de pgina
Incluso podemos agrupar los botones con los atributos data-role="controlgroup" y
data-type="horizontal".
<div data-role="footer" class="ui-bar">
<div data-role="controlgroup" data-type="horizontal">
<a href="index.html" data-role="button"
data-icon="delete">Remove</a>
<a href="index.html" data-role="button"
data-icon="plus">Add</a>
<a href="index.html" data-role="button"
data-icon="arrow-u">Up</a>
<a href="index.html" data-role="button"
data-icon="arrow-d">Down</a>
</div>
</div>

Pie de pgina
9.3.4. Barras de navegacin
jQuery Mobile tiene tambin una caracterstica que permite aadir barras de navegacin
en nuestras aplicaciones. Estas barras permiten hasta cinco botones con la posibilidad
incluso de aadir iconos y normalmente se sitan dentro de la cabecera o del pie de
pgina.

143

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Una barra de navegacin no es ms que una lista desordenada de enlaces que se encuentra
dentro de elemento con el atributo data-role="navbar". Si queremos marcar una
determinada opcin de esta barra de navegacin como activa podemos especificar el
atributo class="ui-btn-active" en el enlace.
<div data-role="footer">
<div data-role="navbar">
<ul>
<li><a href="a.html"
class="ui-btn-active">One</a></li>
<li><a href="b.html">Two</a></li>
</ul>
</div><!-- /navbar -->
</div><!-- /footer -->

Pie de pgina
A medida que vayamos aumentando el nmero de botones en la barra de navegacin,
jQuery Mobile se encargar automticamente de posicionarlos correctamente en el
navegador, tal y como vemos en las siguientes imgenes.

Pie de pgina con 3 botones

Pie de pgina con 4 botones

Pie de pgina con 5 botones

Pie de pgina con muchos botones


Comentar tambin que los botones de nuestras barras de navegacin pueden ir
144

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

acompaados de iconos que mejoren la experiencia del usuario final. Estos iconos se
pueden aadir a los enlaces mediante el atributo data-icon especificndole un valor de
entre los siguientes:
arrow-l
arrow-r
arrow-u
arrow-d
delete
plus
minus
check
gear
refresh
forward
back
grid
star
alert
info
home
search
Por ltimo, comentar tambin que estos iconos aparecen por defecto a la izquierda del
texto, pero si queremos colocarlos en cualquier otro lugar podemos utilizar el atributo
data-iconpos con cualquiera de estos valores:
left
right
top
bottom

9.4. Formateo de contenido


El contenido de las pginas de una aplicacin desarrollada con jQuery Mobile es
totalmente abierto, aunque como siempre, siguiendo una serie de convenciones, el
framework nos ayudar muchsimo en nuestra tarea. En esta seccin veremos algunos
aspectos interesantes como son los paneles desplegables y los diseos para mltiples
columnas que nos facilitarn el formateo de contenido para aplicaciones mviles.
9.4.1. HTML bsico
Lo ms importante de jQuery Mobile es que para formatear contenido no tenemos ms
que aplicar los conocimientos del lenguaje HTML. Por su parte, el framework se
encargar de modificar la apariencia de nuestras aplicaciones.

145

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Por defecto, jQuery Mobile utiliza los estilos y tamaos estndar de HTML, tal y como se
muestran en los siguientes ejemplos:
<h1>Cabecera
<h2>Cabecera
<h3>Cabecera
<h4>Cabecera
<h5>Cabecera
<h6>Cabecera

H1</h1>
H2</h2>
H3</h3>
H4</h4>
H5</h5>
H6</h6>

Cabeceras
<ol>
<li>Lista desordenada item 1</li>
<li>Lista desordenada item 2</li>
<li>Lista desordenada item 3</li>
</ol>

Listas desordenadas
<table>
<thead>
<tr>
<th>ISBN</th>
<th>Ttulo</th>
<th>Autor</th>
</tr>
</thead>
<tbody>
<tr>
<td>843992688X</td>
<td>La colmena</td>
<td>Camilo Jos Cela Trulock</td>
</tr>

146

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<tr>
<td>0936388110</td>
<td>La galatea</td>
<td>Miguel de Cervantes Saavedra</td>
</tr>
<tr>
<td>8437624045</td>
<td>La dragontea</td>
<td>Flix Lope de Vega y Carpio</td>
</tr>
</tbody>
</table>

Tablas
Como puedes observar, la apariencia de la mayora de los componentes HTML no
difieren prcticamente en nada de lo que ya conoces del desarrollo de aplicaciones web de
escritorio.
Sin embargo, a continuacin vamos a ver algunos componentes HTML que enmarcados
dentro de une web desarrollada con jQuery Mobile facilitar la labor de estructuracin de
la informacin en una aplicacin web para mviles.
9.4.2. Diseos por columnas
Aunque el diseo por columnas no es muy habitual verlo en aplicaciones web para
mviles debido a la propia idiosincrasia de los dispositivos mviles y su amplitud, en
algunas ocasiones este tipo de diseos se hace necesario para aprovechar al mximo esta
amplitud.
jQuery Mobile tiene como convencin para este tipo de diseos una clase llamada ui-grid
y que bsicamente utiliza una serie de diseos CSS para generar un diseo por columnas,
en el que se permiten hasta un mximo de 5 columnas.
En funcin del nmero de columnas que necesitemos en nuestro diseos, la capa
contenedora debe tener el atributo class a uno de estos valores:
1. 2 columnas: ui-grid-a
2. 3 columnas: ui-grid-b
3. 4 columnas: ui-grid-c
4. 5 columnas: ui-grid-d
Veamos el siguiente cdigo y analicmoslo:
<div class="ui-grid-a">
<div class="ui-block-a"><div class="ui-bar ui-bar-a">Block
A</div></div>

147

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<div class="ui-block-b"><div
B</div></div>
</div>
<br/>
<div class="ui-grid-b">
<div class="ui-block-a"><div
A</div></div>
<div class="ui-block-b"><div
B</div></div>
<div class="ui-block-c"><div
C</div></div>
</div>
<br/>
<div class="ui-grid-c">
<div class="ui-block-a"><div
A</div></div>
<div class="ui-block-b"><div
B</div></div>
<div class="ui-block-c"><div
C</div></div>
<div class="ui-block-d"><div
D</div></div>
</div>
<br/>
<div class="ui-grid-d">
<div class="ui-block-a"><div
A</div></div>
<div class="ui-block-b"><div
B</div></div>
<div class="ui-block-c"><div
C</div></div>
<div class="ui-block-d"><div
D</div></div>
<div class="ui-block-e"><div
E</div></div>
</div>

class="ui-bar ui-bar-b">Block

class="ui-bar ui-bar-a">Block
class="ui-bar ui-bar-b">Block
class="ui-bar ui-bar-c">Block

class="ui-bar ui-bar-a">Block
class="ui-bar ui-bar-b">Block
class="ui-bar ui-bar-c">Block
class="ui-bar ui-bar-d">Block

class="ui-bar ui-bar-a">Block
class="ui-bar ui-bar-b">Block
class="ui-bar ui-bar-c">Block
class="ui-bar ui-bar-d">Block
class="ui-bar ui-bar-e">Block

Este cdigo HTML producira la siguiente salida:

Diseo por columnas


Como vemos en la imagen, cada bloque est identificado por el atribudo
class="ui-grid" diferente en funcin del nmero de columnas. Posteriormente, cada
elemento debe estar a su vez contenido por una capa con el atributo class="ui-block"
que indicar la posicin del contenido en el diseo por columnas. Por ltimo, tener en

148

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

cuenta que el diseo del contenido mostrado, depender del atributo class="ui-bar"
especificado, tal y como se muestra en la imagen.
Por ltimo comentar tambin que la idea de los diseos por columnas es organizar en filas
una serie de elementos. En ocasiones, nos puede interesar agrupar en un diseo de tres
columnas a nueve elementos, con lo que jQuery Mobile metera tres elementos por cada
fila tal y como vemos en el siguiente ejemplo.
<div class="ui-grid-c">
<div class="ui-block-a"><div
1</div></div>
<div class="ui-block-b"><div
2</div></div>
<div class="ui-block-c"><div
3</div></div>
<div class="ui-block-a"><div
4</div></div>
<div class="ui-block-b"><div
5</div></div>
<div class="ui-block-c"><div
6</div></div>
<div class="ui-block-a"><div
7</div></div>
<div class="ui-block-b"><div
8</div></div>
<div class="ui-block-c"><div
9</div></div>
</div>

class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block
class="ui-bar ui-bar-e">Block

Multiples columnas y filas


9.4.3. Contenido desplegable
jQuery Mobile permite incluso agrupar contenido que se mostrar en forma de
desplegable cuando el usuario haga clic sobre el mismo. El formato de este tipo de
contenidos es muy sencillo y simplemente debemos utilizar el atributo
data-role="collapsible" seguido de un elemento de encabezado, como por ejemplo
<h3/> y el contenido a mostrar. jQuery Mobile se encargar incluso de pintar un botn
para que el usuario detecte que puede hacer clic sobre ste, tal y como vemos en el
siguiente ejemplo.
<div data-role="collapsible">
<h3>Contenido desplegable</h3>
<p>
Este contenido puede ser mostrado y
ocultado por el usuario simplemente haciendo
clic en la cabecera
</p>

149

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

</div>

Contenido desplegable
Como puedes observar, este contenido aparece desplegado al cargar la pgina. Si quieres
que el mismo aparezca contrado debes aadir el atributo data-collapsed="true" de la
siguiente forma:
<div data-role="collapsible" data-collapsed="true"></div>

Comentar por ltimo que el contenido de estos desplegables puede ir desde un simple
prrafo hasta incluso un formulario y que incluso vamos a poder insertar un contenido
desplegable dentro de otro, tal y como vemos en este ejemplo.
<div data-role="collapsible">
<h3>Contenido desplegable</h3>
<p>Este contenido est dentro de un desplegable...</p>
<div data-role="collapsible">
<h4>ms informacin</h4>
<p>... que a su vez tiene ms contenido desplegable</p>
</div>
</div>

Contenido desplegable anidado


9.4.4. Contenidos desplegables agrupados (acordeones)
Los acordeones no son ms que un conjunto de contenidos desplegables de tal forma que
al hacer clic sobre uno de ellos, el resto se ocultarn automticamente, con lo que nunca
podr haber ms de uno elemento desplegado al mismo tiempo.
La sintaxis de estos acordeones es prcticamente la misma que veamos anteriormente
salvo que ahora debemos aadir un elemento que agrupar a todos estos contenidos
desplegables y al cual le debemos asignar el atributo data-role="collapsible-set". Si
queremos mostrar de inicio alguno de estos desplegables, debemos asignar el atributo
150

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

data-collapsed="false".
<div data-role="collapsible-set">
<div data-role="collapsible" data-collapsed="true">
<h3>Seccin A</h3>
<p>Contenido desplega para A.</p>
</div>
<div data-role="collapsible" data-collapsed="true">
<h3>Seccin B</h3>
<p>Contenido desplega para B.</p>
</div>
<div data-role="collapsible" data-collapsed="false">
<h3>Seccin C</h3>
<p>Contenido desplega para C.</p>
</div>
<div data-role="collapsible" data-collapsed="true">
<h3>Seccin D</h3>
<p>Contenido desplega para D.</p>
</div>
</div>

Grupo de elementos desplegables

151

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

10. Ejercicios - Introduccin a jQuery Mobile


En la parte dedicada a los ejercicios de jQuery Mobile vamos a desarrollar una parte muy
reducida de una aplicacin destinada a la gestin de una biblioteca de un centro
educativo. Esta biblioteca bsicamente contar por supuesto con libros y con una serie de
tipos de usuario que podrn hacer realizar una serie de operaciones. En otras partes de
este curso de especialista, desarrollaremos ms ampliamente esta aplicacin, pero en esta
parte dedicada a la programacin web con jQuery Mobile nos quedaremos en algo muy
sencillo como es la interfaz de usuario desde el punto de vista del alumno

10.1. Ejercicio 1 - Inicio de la aplicacin


En este primer ejercicio vamos a empezar por preparar la interfaz de usuario de lo que
ser nuestra aplicacin y a definir el comportamiento de determinadas pantallas de la
misma. Empecemos creando la pgina que ser la portada de nuestra aplicacin. Esta
pgina debe contener una cabecera indicando el nombre de nuestra aplicacin que
llamaremos iBiblioteca.
A continuacin, vamos a definir lo que ser el contenido de esa pgina de inicio. Aqu
vamos a redactar un pequeo texto formateado explicando brevemente el funcionamiento
de la aplicacin. Que no se te olvide indicar tambin quien ha desarrollado esta
aplicacin.
Aviso:
Las pginas de inicio en el mundo de las aplicaciones web para mvil no son nada deseables ya
que lo ms recomendable es que el usuario pueda directamente interactuar con la aplicacin sin
necesidad de aterrizar en una pgina de inicio que siempre muestra la misma informacin.

Por ltimo, crear tambin un pie de pgina con una barra de navegacin que nos servir
para tener siempre disponible una serie de opciones en cada pgina de nuestra aplicacin.
En esta primera pgina de la aplicacin las opciones que vamos a aadir sern las
siguientes:
Botn para configurar una serie de ajustes en nuestra aplicacin
Botn para mostrar una pequea ayuda de lo que nuestra aplicacin puede hacer
No olvides poner unos iconos de acuerdo a la funcionalidad de cada botn y asegrate
tambin que esta barra de herramientas est siempre visible por el usuario.
El archivo html creado en este ejercicio se debe llamar index.html y debe estar en la raz
de un directorio llamado ibiblioteca.

10.2. Ejercicio 2 - Pgina del autor

152

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En el ejercicio anterior hemos indicado en la pgina de bienvenida a la aplicacin quien


es el autor de la misma, sin embargo, no hemos aadido ms informacin al mismo. En
este ejercicio vamos a crear un nuevo documento html con toda la informacin del autor y
en l practicaremos como crear una estructura de navegacin sencilla para el usuario para
que pueda moverse por la aplicacin sin problemas.
Este nuevo documento relativo al autor tendr ms de una pgina y en cada una de ellas
aadiremos unos datos diferentes. En una primera pgina incluiremos datos como el
nombre completo y otros como el correo electrnico o los telfonos de contacto. Incluso
podemos aadir tambin una foto de tamao reducido.
En una segunda pgina aadiremos informacin relativa a nuestro puesto actual
(programador, analista, arquitecto, etc) y un pequeo listado de los puestos ocupados
recientemente, cada uno de ellos con un enlace que nos llevar a una tercera pgina donde
se explicar el cargo ocupado en ese puesto.
Ten en cuenta que siempre debemos volver atrs en todas las pantallas de nuestra
aplicacin. Recuerda tambin especificar una transicin idnea para estos enlaces.
El archivo html creado en este ejercicio se debe llamar author.html y debe estar en la raz
de un directorio llamado ibiblioteca. Para la fotografa del autor, crea un directorio
llamado images y ponla en la raz de este directorio.

10.3. Ejercicio 3 - Listado de libros


En este ejercicio vamos a preparar una pgina en la que mostrar todos los libros de
nuestra biblioteca y para ello utilizaremos los acordeones. En estos acordeones
presentaremos en primer lugar el ttulo del libro y una vez hagamos clic en ellos,
mostraremos otras opciones de los libros como son el autor, el isbn y la editorial.
En el siguiente enlace podis descargaros tanto un xml con libros de ejemplo como sus
correspondientes imgenes de las portadas de los libros.
En cada libro, adems daremos la posibilidad al usuario para que realice una reserva del
mismo y marcarlo como favorito. Utiliza un tema diferente en estos enlaces para resaltar
las opciones. Aade por ltimo una opcin a cada libro para que se pueda ver la portada
del libro.
El archivo html creado en este ejercicio se debe llamar books.html y debe estar en la raz
de un directorio llamado ibiblioteca.

153

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

11. Aspectos avanzados de jQuery Mobile


Una vez vistos los aspectos ms bsicos de jQuery Mobile, en esta sesin vamos a
profundizar en aspectos algo ms avanzados y empezaremos viendo como podemos
introducir listas de elementos (algo tan habitual en las aplicaciones web para mviles).
Seguiremos analizando todos los elementos de formulario con las peculiaridades que se
incluyen en jQuery Mobile. Por ltimo, veremos algunos ejemplos para consumir
servicios REST en nuestras aplicaciones web para mviles.

11.1. Listados de elementos


Uno de los aspectos ms importantes en cualquier aplicacin web para mviles es la
forma en la que se muestran los listados. Debemos tener siempre en cuenta el espacio
limitado que tenemos en una pantalla de un dispositivo mvil, con lo que estos listados
deben aprovechar al mximo este espacio limitado.
Los listados de elementos nos servirn entre otras cosas para mostrar datos, para crear un
sistema de navegacin, para mostrar listas de resultados e incluso para crear sistemas de
entrada de informacin. jQuery Mobile tiene una gran variedad de tipos de listas que
cubrirn la mayora de nuestras necesidades. Pasemos a ver estos tipos de listas y todas
sus caractersticas.
11.1.1. Listados bsicos con enlaces
Un listado en jQuery Mobile no es ms que una lista desordenada en la que sus elementos
son enlaces y que tiene el atributo data-role="listview". Cuando jQuery Mobile
detecte este elemento del DOM lo transformar en una lista adaptada a los dispositivos
mviles y le aadir incluso una flecha a la parte derecha para indicar al usuario que en
ese elemento es posible hacer clic.
Cuando el usuario haga clic en el enlace, ste se cargar va AJAX mostrando una
transicin de pgina. Veamos un poco de cdigo:
<ul data-role="listview" data-theme="g">
<li><a href="audi.html">Audi</a></li>
<li><a href="bmw.html">BMW</a></li>
<li><a href="volkswagen.html">Volkswagen</a></li>
</ul>

154

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listados bsicos
11.1.2. Listados anidados
El concepto de listados anidados es tan simple como incluir una lista dentro de otra. En
estos casos, jQuery Mobile se encargar de mostrar las listas de forma separada. Esto es,
en primer lugar se mostrar la lista principal y al pinchar en cada uno de los elementos se
mostrar la sublista incluida en ese elemento. Veamos un ejemplo:
<ul data-role="listview" data-theme="g">
<li>
Audi
<ul data-role="listview">
<li>A1</li>
<li>A2</li>
<li>A3</li>
</ul>
</li>
<li>
BMW
<ul data-role="listview">
<li>Serie 1</li>
<li>Serie 2</li>
<li>Serie 3</li>
</ul>
</li>
<li>
Volkswagen
<ul>
<li>Golf</li>
<li>Passat</li>
<li>Touran</li>
</ul>
</li>
</ul>

155

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listados bsicos

Listados anidados
11.1.3. Listados numerados
Hasta ahora siempre hemos visto los listados no numerados, sin embargo, en jQuery
Mobile tambin es posible utilizar los listados numerados. Un tpico caso de listado
numerado puede ser el resultado de una bsqueda o para indicar por la clasificacin de un
torneo cualquiera.
<ol data-role="listview" data-theme="g">
<li><a href="barca.html">Barcelona</a></li>
<li><a href="levante.html">Levante</a></li>
<li><a href="realmadrid.html">Real Madrid</a></li>
<li><a href="malaga.html">Mlaga</a></li>
<li><a href="valencia.html">Valencia</a></li>
<li><a href="sevilla.html">Sevilla</a></li>
<li><a href="betis.html">Betis</a></li>
<li><a href="atletico.html">Atltico</a></li>
<li><a href="rsociedad.html">Real Sociedad</a></li>
<li><a href="mallorca.html">Mallorca</a></li>
</ol>

156

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listados numricos
11.1.4. Listados de solo lectura
Por supuesto, no siempre necesitaremos que un elemento de una lista haga una
determinada accin y simplemente vamos a querer mostrar determinada informacin en
este listado. En este tipo de listados vamos a poder tanto listas ordenadas como listas
desordenadas.
11.1.4.1. Listados simples

En este tipo de listados no hay posibilidad de hacer clic sobre los elementos de la lista e
incluso el tamao del texto es considerablemente ms pequeo que en las listas con
enlaces. Imagina por ejemplo un simple listado de alumnos.
<ul data-role="listview" data-theme="g">
<li>Alacid Magn, Emilio</li>
<li>Blasco Lpez, Sonia</li>
<li>Gabaldn Santander, Nicolas</li>
<li>Garca Snchez, Ana Mara</li>
<li>Guerrero Hurtado, Carlos</li>
<li>Salinas Ruiz, Jos Manuel</li>
<li>Sansano Alicante, Lorena</li>
</ul>

157

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listas bsicas de solo lectura


11.1.4.2. Listados simples con informacin nmerica

En ocasiones, estos listados de solo lectura proporcionan algo de informacin numrica.


Continuando con el ejemplo anterior de los alumnos podramos tener una nota asociada a
los mismos. Para introducir esta informacin numrica nicamente debemos aadir un
elemento de tipo div con el atributo class="ui-list-count".
<ul data-role="listview" data-theme="g">
<li>Alacid Magn, Emilio <span class="ui-li-count">9,5</span></li>
<li>Blasco Lpez, Sonia <span class="ui-li-count">6,5</span></li>
<li>Gabaldn Santander, Nicolas <span
class="ui-li-count">5</span></li>
<li>Garca Snchez, Ana Mara <span
class="ui-li-count">7</span></li>
<li>Guerrero Hurtado, Carlos <span
class="ui-li-count">9</span></li>
<li>Salinas Ruiz, Jos Manuel <span
class="ui-li-count">4</span></li>
<li>Sansano Alicante, Lorena <span
class="ui-li-count">7</span></li>
</ul>

158

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listas bsicas de solo lectura con informacin numrica


11.1.4.3. Listados formateados

Por supuesto, no tenemos porque utilizar elementos de una sola lnea sino que stos
pueden estar formados por ms de una lnea indicando informacin complementaria al
elemento.
<ul data-role="listview">
<li>
<h3>Alacid, Emilio</h3>
<p><strong>Un fenmeno en las matemticas</strong></p>
<p>Comentar el incidente de los pinceles</p>
<p class="ui-li-aside"><strong>17:10</strong></p>
</li>
<li>
<h3>Blasco, Sonia</h3>
<p><strong>Atiende mucho en clase</strong></p>
<p>En ocasiones viene sin los deberes hechos</p>
<p class="ui-li-aside"><strong>17:35</strong></p>
</li>
<li>
<h3>Gabaldn, Nicolas</h3>
<p><strong>Le encanta el medio ambiente</strong></p>
<p>Se despista con una mosca</p>
<p class="ui-li-aside"><strong>18:00</strong></p>
</li>
</ul>

159

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listas bsicas de solo lectura con informacin formateada


11.1.4.4. Listados con imgenes

Por supuesto, en los listados tambin vamos a poder aadir imgenes como si fuera
iconos para facilitar la comprensin por parte del usuario. Simplemente debemos aadir
la imagen que queramos mostrar e indicarle el atributo class="ui-li-icon".
<ul data-role="listview">
<li><img src="images/ar.png" alt="Messi" class="ui-li-icon">
Messi <span class="ui-li-count">8</span>
</li>
<li><img src="images/pt.png" alt="Cristiano" class="ui-li-icon">
Cristiano <span class="ui-li-count">7</span>
</li>
<li><img src="images/es.png" alt="Soldado" class="ui-li-icon">
Soldado <span class="ui-li-count">5</span>
</li>
<li><img src="images/co.png" alt="Falcao" class="ui-li-icon">
Falcao <span class="ui-li-count">5</span>
</li>
<li><img src="images/ar.png" alt="Higuan" class="ui-li-icon">
Higuan <span class="ui-li-count">5</span>
</li>
<li><img src="images/es.png" alt="Cazorla" class="ui-li-icon">
Cazorla <span class="ui-li-count">4</span>
</li>
</ul>

160

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listas bsicas de solo lectura con iconos


Aqu tienes los iconos de las imgenes
11.1.4.5. Listados con thumbnails

Otro tipo de listado similar al de las imgenes sera aquellos listados que se presentan con
una imagen de tipo thumbnail asociada al texto. Piensa por ejemplo un listado de lbumes
musicales.
<ul data-role="listview">
<li>
<img src="images/album-bb.jpg" />
<h3>Broken Bells</h3>
<p>Broken Bells</p>
</li>
<li>
<img src="images/album-hc.jpg" />
<h3>Warning</h3>
<p>Hot Chip</p>
</li>
<li>
<img src="images/album-p.jpg" />
<h3>Wolfgang Amadeus Phoenix</h3>
<p>Phoenix</p>
</li>

161

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

</ul>

Listas bsicas de solo lectura con iconos


11.1.5. Listados divididos y agrupados
Otra posibilidad de los listados es mostrarlos agrupados por ejemplo por orden alfabtico.
Estos listados se pueden implementar fcilmente simplemente indicando en el elemento
divisor el atributo data-role="list-divider" tal y como vemos en el siguiente
ejemplo.
<ul data-role="listview">
<li data-role="list-divider">A</li>
<li><a href="index.html">Adam Kinkaid</a></li>
<li><a href="index.html">Alex Wickerham</a></li>
<li><a href="index.html">Avery Johnson</a></li>
<li data-role="list-divider">B</li>
<li><a href="index.html">Bob Cabot</a></li>
<li data-role="list-divider">C</li>
<li><a href="index.html">Caleb Booth</a></li>
<li><a href="index.html">Christopher Adams</a></li>
<li><a href="index.html">Culver James</a></li>
</ul>

162

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listas agrupadas
11.1.6. Listados con filtros
jQuery Mobile adems incorpora la posibilidad de implementar fcilmente la bsqueda de
textos en las listas de nuestras aplicaciones. Esto se puede conseguir simplemente
indicando el atributo data-filter="true" a la lista en cuestin.
Con esto veremos que jQuery Mobile aadir una caja de texto para la bsqueda de texto
en los elementos de nuestra lista que nos servir para filtrar nicamente aquellos
elementos que contengan el texto buscado. Esta caja de texto vendr completada con un
texto
por
defecto
que
podremos
cambiar
modificando
el
atributo
data-filter-placeholder="Filtro de bsqueda".
<ul data-role="listview" data-filter="true"
data-filter-placeholder="Filtro de bsqueda">
<li>Alacid Magn, Emilio <span class="ui-li-count">9,5</span></li>
<li>Blasco Lpez, Sonia <span class="ui-li-count">6,5</span></li>
<li>Gabaldn Santander, Nicolas <span
class="ui-li-count">5</span></li>
<li>Garca Snchez, Ana Mara <span class="ui-li-count">7</span></li>
<li>Guerrero Hurtado, Carlos <span class="ui-li-count">9</span></li>
<li>Salinas Ruiz, Jos Manuel <span class="ui-li-count">4</span></li>
<li>Sansano Alicante, Lorena <span class="ui-li-count">7</span></li>
</ul>

163

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Listas con filtros

11.2. Formularios
Sin duda, uno de los aspectos ms importantes de cualquier aplicacin web ya est
dirigida a un entorno mvil o de escritorio es la interaccin con el usuario mediante
formularios.
En jQuery Mobile, todos los elementos de formulario siguen el estndar de HTML
aadindole algunas caractersticas para hacerlos ms atractivos sobre todo a nivel visual
y de usabilidad en un dispositivo mvil.
En aquellos navegadores que no soporten las transformaciones oportunas, estos elementos
se vern sin ningn problema pero con el diseo habitual de los mismos.
11.2.1. Conceptos bsicos
Por supuesto, para crear un formulario debemos utilizar, como se hace en HTML
habitualmente, la etiqueta form seguido de los atributos action para indicar quien se
encargar de procesar esa peticin y method que nos servir para sealar como queremos
pasar esos datos (habitualmente GET o POST).

164

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<form action="form.php" method="post">


...
</form>

Por suerte, todo lo que ya conocemos a la hora de crear formularios en HTML nos va a
servir cuando creemos formularios con jQuery Mobile. Sin embargo, debemos tener en
cuenta que todos los elementos de un formulario deben especificar el atributo id. Este
atributo habitualmente debe ser nico en cada pgina HTML, sin embargo, con jQuery
Mobile este atributo no puede repetirse a lo largo de toda la aplicacin ya que jQuery
Mobile trabaja modificando el DOM y no es posible tener dos elementos cargados con el
mismo identificador.
Adems, es muy importante que se utilice la etiqueta label con el atributo for
especificando el elemento de formulario que queremos etiquetar.
jQuery Mobile siempre trabaja de la misma forma. Cuando el usuario carga una
determinada pgina, se analiza todo el DOM y se realizan una serie de sustituciones. Por
ejemplo, cuando utilizamos un elemento de formulario de tipo select, jQuery Mobile
utiliza un plugin llamado selectmenu y realiza las sustituciones indicadas en este plugin.
Esto es lo que hace jQuery Mobile por defecto, sin embargo nosotros podemos indicarle a
un determinado elemento de formulario que no queremos que se realice ninguna
sustitucin simplemente aadindole el atributo data-role="none", tal y como vemos
en el siguiente ejemplo.
<label for="marcacoche">Marca</label>
<select name="marcacoche" id="marcacoche" data-role="none">
<option value="audi" >Audi</option>
<option value="bmw" >BMW</option>
<option value="volkswagen" >Volkswagen</option>
</select>

Algo tambin muy interesante es como se organizan los diversos elementos de un


formulario y es que jQuery Mobile trata de posicionar todos estos elementos para
aprovechar al mximo el ancho de un dispositivo mvil.
Por ejemplo, en aquellos dispositivos estrechos, los elementos label se situan justo
encima del elemento de formulario al que etiquetan. Sin embargo, en los dispositivos ms
anchos, estas etiquetas aparecen a la izquierda de su elemento de formulario.
Por ltimo, comentar tambin que para mejorar la experiencia del usuario con los
formularios, es aconsejable utilizar elementos de tipo div o fieldset con el atributo
data-role="fieldcontain" para envolver todos los elementos del formulario.
11.2.2. Elementos de formularios
Veamos a continuacin detalladamente todos los elementos de formulario y sus
caractersticas especficas en jQuery Mobile.

165

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

11.2.2.1. Cajas de texto

Las cajas de texto de una sola lnea se insertan como si fuera HTML puro y duro y jQuery
Mobile se encargar de hacerlos ms atractivos y fciles de utilizar para un usuario con
un dispositivo mvil, tal y como vemos en el siguiente ejemplo.
<div data-role="fieldcontain">
<label for="name">Nombre</label>
<input type="text" name="name" id="name" value=""
</div>

/>

Cajas de texto
Adems, en jQuery Mobile tambin podemos utilizar cualquiera de los nuevos tipos
introducidos en HTML5 (password, email, tel, number, url, etc).
<div data-role="fieldcontain">
<label for="email">Correo electrnico</label>
<input type="email" name="email" id="email" value="" />
<label for="password">Contrasea</label>
<input type="password" name="password" id="password" value="" />
<label for="age">Edad</label>
<input type="number" name="age" id="age" value="" />
<label for="url">Url</label>
<input type="url" name="url" id="url" value="" />
<label for="telephone">Telfono</label>
<input type="tel" name="telephone" id="telephone" value="" />
</div>

166

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Ms opciones de las cajas de texto


Si compruebas este ejemplo, vers que al intentar editar cada una de las cajas de texto el
mtodo de entrada ser diferente.
Tambin podemos utilizar las cajas de texto multilnea textarea que tambin siguen el
mismo formato que en HTML y es jQuery Mobile quien se encargar de ajustar la altura
para evitar tener que pintar un scroll innecesario a medida que el usuario va escribiendo.
<div data-role="fieldcontain">
<label for="description">Descripcin</label>
<textarea name="description" id="description"></textarea>
</div>

Por ltimo, en HTML5 se ha aadido un nuevo tipo llamado search, que como su
nombre indica nos servir para introducir cajas de texto que se utilizarn para
implementar bsquedas en nuestra aplicacin.
<div data-role="fieldcontain">
<label for="search">Buscar</label>
<input type="search" name="search" id="search" placeholder="texto a
buscar" value="" />
</div>

167

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Cajas de bsqueda de texto


11.2.2.2. Deslizadores

Uno de los elementos introducidos en la especificacin del HTML5 ha sido la posibilidad


de utilizar el elemento de formulario de tipo range. El usuario podr deslizar fcilmente
este elemento y al mismo ir tomando un valor diferente para cada posicin.
En estos elementos debemos especificar los atributos min y max que servirn para indicar
un valor mnimo y un mximo y por otro lado, tambin podemos indicarle un valor actual
con el atributo value.
<div data-role="fieldcontain">
<label for="age">Edad</label>
<input type="range" name="age" id="age" value="25" min="0" max="100"
/>
</div>

Deslizador
Como vemos en la imagen, a la izquierda del deslizador aparece una caja de texto de tal
forma que el usuario podr utilizar ste o bien ser ms preciso escribiendo el texto
directamente, lo que se ver automticamente reflejado en el deslizador.
11.2.2.3. Switchers

En jQuery Mobile tenemos tambin la posibilidad de aadir un elemento de formulario


nuevo que nos permitir indicar al usuario que debe elegir entre dos valores, como
pueden ser on/off o true/false. Este elemento se mostrar de tal forma que el usuario podr
con sus dedos cambiar el estado del mismo fcilmente.
Estos elementos se definen como si fuera un elemento de tipo select con dos opciones.
Adems, el select debe tener el atributo data-role="slider". El primer elemento del
select ser tratado como el estado on o true, mientras que el segundo ser off o false.
<div data-role="fieldcontain">
<label for="casado">Casado</label>
<select name="casado" id="casado" data-role="slider">
<option value="no">No</option>
<option value="yes">S</option>
</select>
</div>

168

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Switcher
11.2.2.4. Elementos de tipo radio

Este tipo de elementos se utilizan para proporcionar al usuario una serie de elementos de
los cuales ste debe seleccionar solamente uno. En las aplicaciones de escritorio este tipo
de elementos no estn optimizados para el uso en dispositivos mviles, pero con jQuery
Mobile stos se nos mostrarn mucho ms accesibles.
Para crear un conjunto de elementos de tipo radio simplemente debemos aadir la
etiqueta input con el atributo type="radio" y su correspondiente label.
Es aconsejable adems que todos los elementos de tipo radio queden envueltos en las
etiquetas fieldset y legend. Esta ltima actuar como ttulo del elemento.
Por ltimo, la etiqueta fieldset debe quedar envuelta a su vez por una etiqueta div con
el atributo data-role="controlgroup", tal y como vemos en el siguiente ejemplo.
<div data-role="fieldcontain">
<fieldset data-role="controlgroup">
<legend>Marca de coche</legend>
<input type="radio" name="radio-choice-1"
id="radio-choice-1" value="audi" checked="checked" />
<label for="radio-choice-1">Audi</label>
<input type="radio" name="radio-choice-1"
id="radio-choice-2" value="bmw" />
<label for="radio-choice-2">BMW</label>
<input type="radio" name="radio-choice-1"
id="radio-choice-3" value="seat" />
<label for="radio-choice-3">Seat</label>
<input type="radio" name="radio-choice-1"
id="radio-choice-4" value="volkswagen" />
<label for="radio-choice-4">Volkswagen</label>
</fieldset>
</div>

169

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Radio vertical
En el ejemplo anterior, el grupo de elementos aparece de forma vertical, pero tambin es
posible que aparezcan horizontalmente simplemente especificando el atributo
data-type="horizontal" a la etiqueta fieldset.
<div data-role="fieldcontain">
<fieldset data-role="controlgroup" data-type="horizontal">
<legend>Modelo de Audi</legend>
<input type="radio" name="radio-choice-1"
id="radio-choice-1" value="a1" checked="checked" />
<label for="radio-choice-1">A1</label>
<input type="radio" name="radio-choice-1"
id="radio-choice-2" value="a2" />
<label for="radio-choice-2">A2</label>
<input type="radio" name="radio-choice-1"
id="radio-choice-3" value="a3" />
<label for="radio-choice-3">A3</label>
</fieldset>
</div>

Radio horizontal
11.2.2.5. Elementos de tipo checkbox

Este tipo de elementos se utilizan para proporcionar al usuario una serie de opciones de
las cuales puede seleccionar ms de una. Al igual que los elementos de tipo radio, los
elementos de tipo checkbox utilizan la misma sintaxis que en HTML puro y duro y es

170

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

jQuery Mobile el encargado de realizar las transformaciones oportunas para adaptarlas a


un entorno mvil.
Para aadir uno de estos elementos debemos utilizar la etiqueta input con el atributo
type="checkbox" y su correspondiente etiqueta label con el atributo for correctamente
asociado al identificador del checkbox.
Por ltimo y al igual que sucedia con los elementos de tipo radio , la etiqueta fieldset
debe quedar envuelta a su vez por una etiqueta div con el atributo
data-role="controlgroup", tal y como vemos en el siguiente ejemplo.
<div data-role="fieldcontain">
<fieldset data-role="controlgroup">
<legend>De acuerdo con los trminos del contrato:</legend>
<input type="checkbox" name="checkbox-1" id="checkbox-1"
class="custom" />
<label for="checkbox-1">S, estoy de acuerdo</label>
</fieldset>
</div>

Checkbox horizontal
Por defecto, los elementos de tipo checkbox aparecern agrupados de forma vertical, tal y
como se muestra en el siguiente ejemplo.
<div data-role="fieldcontain">
<fieldset data-role="controlgroup">
<legend>Indquenos sus hobbies</legend>
<input type="checkbox" name="musica" id="musica"/>
<label for="musica">Msica</label>
<input type="checkbox" name="deporte" id="deporte"/>
<label for="deporte">Deportes</label>
<input type="checkbox" name="television" id="television"/>
<label for="television">Televisin</label>
<input type="checkbox" name="cine" id="cine"/>
<label for="cine">Cine</label>
</fieldset>
</div>

171

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Checkbox vertical
Por ltimo, si en lugar de mostrarlos de forma vertical queremos hacerlo de forma
horizontal, podemos aadir el atributo data-type="horizontal".
<div data-role="fieldcontain">
<fieldset data-role="controlgroup" data-type="horizontal">
<legend>Estilo:</legend>
<input type="checkbox" name="bold" id="bold"/>
<label for="bold">b</label>
<input type="checkbox" name="cursive" id="cursive"/>
<label for="cursive"><em>i</em></label>
<input type="checkbox" name="underline" id="underline"/>
<label for="underline">u</label>
</fieldset>
</div>

Checkbox horizontal
11.2.2.6. Elementos de tipo select

Para terminar con los diferentes tipos de elementos de formulario, vamos a ver el
elemento de tipo select. Este tipo nos permitir seleccionar un solo elemento de una
lista.

172

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Como los elemementos de tipo radio y checkbox, stos tambin tienen la sintaxis tpica
de HTML y ser nuevamente jQuery Mobile quien se encargue de realizar las
transformaciones oportunas para mejorar la experiencia del usuario de dispositivos
mviles.
Para aadir un elemento de este tipo debemos utilizar la etiqueta select con una serie de
elementos de tipo option. Debemos tambin relacionar este elemento con una etiqueta de
tipo label. Adems, debemos tambin agrupar este elemento dentro de un elemento de
tipo div con el atributo data-role="fieldcontain". Veamos un ejemplo:
<div data-role="fieldcontain">
<label for="tiposuscripcion">Tipo de suscripcin:</label>
<select name="tiposuscripcion" id="tiposuscripcion">
<option value="diaria">Diara</option>
<option value="semanal">Semanal</option>
<option value="mensual">Mensual</option>
<option value="anual">Anual</option>
</select>
</div>

Select
Como podemos comprobar en la imagen, este tipo de elementos se mostrarn de forma
nativa en los diferentes dispositivos donde carguemos nuestra aplicacin. Si queremos
modificar este comportamiento y mostrar las opciones siempre de la misma forma y con

173

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

algo ms de estilo propio, podemos utilizar el atributo data-native-menu="false" en el


elemento select obteniendo lo siguiente:

Select no nativo
Si necesitas adems en tu aplicacin que tus usuarios puedan utilizar la seccin mltiple,
jQuery Mobile tambin nos va a facilitar esta labor. nicamente debemos aadir a la
etiqueta select el atributo multiple="multiple". Adems, tambin debemos aadir un
primer elemento sin valor que se mostrar como una cabecera del select.
<div data-role="fieldcontain">
<label for="tiposuscripcion">Tipo de suscripcin:</label>
<select name="tiposuscripcion" id="tiposuscripcion" multiple="multiple"
data-native-menu="false">
<option>Selecciona opciones</option>
<option value="diaria">Diara</option>
<option value="semanal">Semanal</option>
<option value="mensual">Mensual</option>
<option value="anual">Anual</option>
</select>
</div>

Select mltiple

174

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Como vemos en la imagen, jQuery Mobile se encarga de poner un encabezado con la


primera opcin del select que adems podremos cerrar con un botn tambin aadido
automticamente.
11.2.3. Botones
Una vez vistos todos los elementos de formulario, pasemos a ver los botones en jQuery
Mobile. Los botones con jQuery Mobile se especifican como si fuera HTML pero como
siempre, stos se presentarn de una forma ms atractiva para los clientes mviles.
Sin embargo, existe otra posibilidad para pintar botones en nuestras aplicaciones que es
especificarlo mediante un enlace con el atributo data-role="button".
<a href="index.html" data-role="button">Botn con enlace</a>

Botn con enlace


Por otro lado, si utilizamos la sintaxis tpica para los botones en HTML, tenemos las
siguientes representaciones.
<button>Elemento button</button>
<input type="button" value="Input type=button" />
<input type="submit" value="Input type=submit" />
<input type="reset" value="Input type=reset" />
<input type="image" value="Input type=image" />

Botn con inputs


Por defecto, los botones se muestra a nivel de bloque, esto es que ocuparn todo el ancho
posible de la pgina. Si queremos pintar ms de un botn en una misma lnea, debemos
utilizar el atributo data-inline="true" a cada botn.

175

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<a href="index.html" data-role="button" data-inline="true">Cancelar</a>


<a href="index.html" data-role="button" data-inline="true"
data-theme="b">Guardar</a>

Botn en lnea
Pero adems, jQuery Mobile nos permite agrupar botones tanto de forma vertical.
<div data-role="controlgroup">
<a href="index.html" data-role="button">S</a>
<a href="index.html" data-role="button">No</a>
<a href="index.html" data-role="button">Quizs</a>
</div>

Botones agrupados
Y en el caso que queramos mostrar los botones de forma horizontal, deberemos utilizar el
atributo
data-type="horizontal"
al
contenedor
con
el
atributo
data-role="controlgroup".
<div data-role="controlgroup" data-type="horizontal">
<a href="index.html" data-role="button">S</a>
<a href="index.html" data-role="button">No</a>
<a href="index.html" data-role="button">Quizs</a>
</div>

Botones agrupados horizontalmente


11.2.4. Envo de formularios
Y por ltimo, ahora que ya conocemos ampliamente como podemos preparar todo tipo de
formularios con jQuery Mobile, vamos a pasar a ver como se enva la informacin
cumplimentada en estos formularios a un servidor que la procese.
jQuery Mobile por defecto procesa el envo de los formularios mediante llamadas Ajax,
creando incluso una transicin entre el formulario y la pgina resultante. Para asegurarnos
de que nuestro formulario se procesa correctamente, debemos especificar los atributos

176

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

action y method. En caso de que no especifiquemos estos valores, el mtodo


GET y el atributo action ser la misma pgina que contiene el formulario.

pasado ser

Los formularios incluso aceptan otros parmetros como data-transition="pop" y


data-direction="reverse". Incluso, si no queremos que el formulario sea procesado
va Ajax, podemos desactivar este comportamiento especificando el atributo
data-ajax="false".
Adems, tambin podemos especificar el atributo
target="_blank".
11.2.5. Consumir servicios REST
Aunque la parte de la programacin del servidor queda fuera de los objetivos de este
curso, vamos a ver una pequea introduccin a un tema muy interesante como es la
consumicin de servicios REST.
Qu es REST?
Es la abreviatura de REpresentational State Transfer y no es ms que un conjunto de principios
en el que se definen una serie de de estndares web y como deben utilizarse stos.

Bsicamente vamos a tener dos formas de consumir estos servicios REST por parte de
terceros. Por un lado el archiconocido formato XML y por otro lado el no tan conocido
formato JSON (que ser el que utilizaremos aqu).
El formato JSON es el acrnimo de Javascript Object Notation y se considera como un
formato ligero para el intercambio de datos entre aplicaciones web. Este puede ser un
ejemplo de archivo json:
{"menu": {
"id": "file",
"value": "File",
"popup": {
"menuitem": [
{"value": "New", "onclick": "CreateNewDoc()"},
{"value": "Open", "onclick": "OpenDoc()"},
{"value": "Close", "onclick": "CloseDoc()"}
]
}
}}

Para consumir servicios REST en formato JSON, jQuery proporciona la llamada


$.getJSON(). El primer parmetro de esta funcin es la URI del servicio REST y el
segundo ser la funcin que se encargar de tramitar esta peticin.
Pero para entender mejor como funciona, veamos un ejemplo que recuperar todos los
libros
de
nuestra
biblioteca.
En
la
direccin
http://server.jtech.ua.es/jbib-rest/resources/libros
tenemos
un
servicio
REST
implementado que nos devolver los libros de una biblioteca. Nuestra tarea ser mostrar
ese listado de libros. Veamos como quedara:
<!DOCTYPE HTML>

177

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<html>
<head>
<meta charset="UTF-8">
<title>Biblioteca</title>
<meta name="viewport" content="width=device-width,
initial-scale=1">
<link rel="stylesheet"
href="http://code.jquery.com/mobile/1.0b2/jquery.mobile-1.0b2.min.css" />
<script type="text/javascript"
src="http://code.jquery.com/jquery-1.6.2.min.js"></script>
<script type="text/javascript"
src="http://code.jquery.com/mobile/1.0b2/jquery.mobile-1.0b2.min.js"></script>
<script text="text/javascript">
$.getJSON('http://server.jtech.ua.es/jbib-rest/resources/libros',
function(data) {
var items = [];
$.each(data['libro'], function(key, val){
items.push('<li data-theme="c" class="ui-btn
ui-btn-icon-right ui-li ui-btn-up-c">' +
'<div class="ui-btn-inner
ui-li"><div class="ui-btn-text">' +
' <a rel="external"
href="librodetalle.php?method=post&url='+ val['link']['@uri'] +'"
class="ui-link-inherit">' + val['@titulo'] +
'</a></div></div>'
+
'<span class="ui-icon
ui-icon-arrow-r"/></li>');
});
$('<ul/>', {
'data-role': 'listview',
'data-filter': 'true',
'class': 'ui-listview',
html: items.join('')
}).appendTo('#listadoLibros');
});
</script>
</head>
<body>
<div data-role="page" id="vistaLibros" data-theme="b">
<div data-role="header" data-position="fixed">
<h2>Biblioteca</h2>
</div>
<div data-role="content" id="listadoLibros">
</div>
</div>
</body>
</html>

Si analizamos un poco el cdigo, veremos como en primer lugar se obtienen todos los
libros
a
partir
del
servicio
REST
pasado
por
parmetro
(http://server.jtech.ua.es/jbib-rest/resources/libros) y una vez con todos los libros, los
vamos aadiendo de forma dinmica en un array (items). Una vez ya tenemos todos los
libros cargados en el array, lo que hacemos es aadirlo al elemento del DOM con
identificador listadoLibros.
Sin embargo, si intentamos cargar el ejemplo anterior, veremos como algo no funcionar
como es debido. Este se produce porque, por motivos de seguridad, es imposible hacer
peticiones javascript a dominios que no nos pertenezcan. Una solucin a este problema es

178

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

utilizar un proxy en nuestro propio servidor que se encargue de procesar dicha peticin.
<?php
if ($_GET['url']=="")
$url = "http://server.jtech.ua.es/jbib-rest/resources/libros";
else
$url = $_GET['url'];
$ch = curl_init($url);
switch (strtolower($_GET['method'])){
case "post":curl_setopt($ch, CURLOPT_POST,1);
curl_setopt($ch,
CURLOPT_USERPWD,"profesor:profesor");
break;
case "delete":
case "put": curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PUT');
curl_setopt($ch,
CURLOPT_USERPWD,"profesor:profesor");
break;
}
curl_exec($ch);
curl_close($ch);
?>

Gracias a este proceso intermedio, ya podremos realizar llamadas al servicio REST que
comentbamos simplemente cambiando el primer parmetro de la funcin $.getJSON()
por el valor curl.php.

179

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Biblioteca con servicios REST

180

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

12. Ejercicios - Aspectos avanzados de jQuery Mobile


12.1. Ejercicio 1: Listado de libros mejorado
En el ltimo ejercicio de la sesin anterior preparbamos un listado de libros que ahora
vamos a mejorar. Sin perder el listado anterior, crearemos una nueva forma de listar los
libros de la biblioteca siguiendo el modelo de hemos visto de listados bsicos.
En este nuevo listado nicamente mostraremos el ttulo y ser una vez que el usuario haga
clic o toque el elemento en cuestin cuando cargaremos los datos de dicho libro en una
nueva pgina. Prueba tambin a utilizar la caracterstica que permite buscar elementos de
una lista desordenada que hemos visto en la seccin de Listados con filtros.
Esta nueva pgina donde se mostrarn los datos del libro seleccionado ser un listado
simple de solo lectura en donde se mostrarn los datos relativos al autor, el ao de
edicin, el isbn y la editorial.
Agregar por ltimo un pie de pgina cuando el usuario est viendo los detalles de un libro
de tal forma que pueda realizar la reserva del libro en cuestin y adems pueda marcarlo
como favorito. Aadir tambin una opcin para que el usuario pueda ver la portada del
libro en forma de cuadro de dilogo (visto en la sesin 3).
El archivo html creado en este ejercicio se debe llamar author.html y debe estar en la raz
de un directorio llamado ibiblioteca.

12.2. Ejercicio 2: Registro de usuarios


En nuestra aplicacin biblioteca, una parte de la misma sern los alumnos y sern ellos
mismos quienes se registren en la aplicacin rellenando un sencillo formulario que vamos
a disear en este ejercicio. Veamos que datos vamos a solicitarles.
En primer lugar, necesitaremos los datos tpicos de cualquier registro, estos son nombre y
apellidos, correo electrnico y una contrasea. Por otro lado, tambin le pediremos al
alumno que nos indique que curso est estudiando para lo que tendr que elegir una
opcin de entre las siguientes opciones:
1 ESO
2 ESO
3 ESO
4 ESO
1 BAT
2 BAT
Por ltimo, el alumno deber marcar que ha ledo las condiciones del registro que podr
leer gracias a un enlace que cargar estas condiciones en forma de cuadro de dilogo.
181

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Puedes descargar este archivo desde este enlace.

12.3. Ejercicio 3: Consumiendo servicios REST


En la parte de teora veamos como podamos generar un listado con los libros a partir de
un servicio REST que nos devuelve un archivo en formato JSON. Si accedemos a la
direccin del servicio REST desde un navegador cualquiera podremos ver como en lugar
de generar un archivo en formato JSON obtendremos el mismo contenido pero en
formato XML, quizs ms legible desde nuestro punto de vista.
Si
echamos
un
vistazo
al
http://server.jtech.ua.es/jbib-rest/resources/libros
comprobaremos como cada libro tiene una url para poder acceder a la informacin del
mismo. Concretamente, el archivo que se encarga de mostrar la informacin de cada libro
es librodetalle.php.
En este ejercicio completaremos la informacin del libro a partir de la informacin del
servicio REST concreto para cada libro. Estos detalles sern los siguientes:
Ttulo
Autor
ISBN
Pginas
Imagen de la portada
Adems, y en funcin de las opciones recibidas de cada libro en el servicio REST,
colocaremos unos botones para cada una de estas opciones.

182

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13. Multimedia
13.1. Transmisin de Audio y vdeo
En esta seccin vamos a ver los diferentes formas de transmisin y formatos de audio y
vdeo que podemos utilizar tanto desde dispositivos mviles como para el acceso a travs
de Web. Las principales formas de hacer llegar estos medios a un mvil o una web son:
Streaming: Emisin de vdeo en directo, o transmisin de radio y TV en Internet.
Descarga progresiva: Podemos reproducir el vdeo mientras se descarga.
Podcast: El dispositivo se sincroniza con nuestras suscripciones.
Integrado en aplicaciones: El contenido se distribuye dentro de una aplicacin.
En las siguientes secciones se explicar en detalle cada una de estas opciones as como
los formatos de audio y vdeo disponibles que podemos utilizar.

13.2. TV mvil y en Internet


La televisin mvil es un formato de televisin que se accede desde un dispositivo mvil
usando el protocolo de transmisin DVB-H. Este protocolo est basado en el estndar
DVB-T utilizado en la TDT, pero con algunas mejoras, como el time-slicing (basado en la
multiplexacin en tiempo de la transmisin de los diferentes servicios, lo que permite un
ahorro de energa de hasta el 90%) y otras tcnicas para eliminar el efecto Doppler
producido en los dispositivos en movimiento.

Pero debido al bajo soporte del DVB-H, se ha popularizando mucho ms el uso de la TV


en Internet. La televisin por Internet, tambin llamada televisin IP o televisin online,
es la televisin distribuida a travs de Internet mediante el protocolo streaming de
transmisin. Cualquier dispositivo con acceso a Internet de banda ancha puede utilizarla
(sin necesidad de estar preparado para otro protocolo especial). Existen multitud de
aplicaciones para las diferentes plataformas que nos permiten su visualizacin:

183

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13.3. Formatos de audio


Un formato de archivo de audio es un contenedor multimedia que guarda una grabacin
de audio (msica, voces, etc.). Lo que hace a un archivo distinto del otro son sus
propiedades: cmo se almacenan los datos, si estn comprimidos o no, sus capacidades de
reproduccin, etc. A continuacin se analizan los formatos de audio que podemos utilizar
en iOS y en Android.
13.3.1. Formatos de audio en iOS
Dado que en los dispositivos iOS contamos con hardware de descompresin, podemos
aprovecharlo para reproducir formatos comprimidos, como los siguientes:
AAC (MPEG-4 Advanced Audio Coding)
ALAC (Apple Lossless)
HE-AAC (MPEG-4 High Efficiency AAC, no software)
MP3 (MPEG-1 audio layer 3)
El hardware slo puede reproducir (descomprimir) un fichero simultneo, si se intenta
reproducir un segundo se har por software. Lo cual resultar demasiado costoso porque
se tendr que realizar la descompresin tambin, en estos casos es preferible utilizar (en
el audio secundario) un formato sin compresin.
Para los formatos sin compresin (o con compresin simple) no es necesario utilizar un
hardware especfico, pues se pueden reproducir por software con escaso coste. Esto nos
permite reproducir varios sonidos simultneos sin generar sobrecarga al sistema. Los
formatos sin compresin son muy tiles para efectos de sonido, mientras que los que
utilizan compresin lo son para reproductores de msica.
Los formatos sin compresin soportados son:
Linear PCM (sin compresin)
IMA4 (IMA/ADPCM)
iLBC (internet Low Bitrate Codec)
-law y a-law

184

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Todos estos formatos pueden ir encapsulados en ficheros de diferente tipo, como:


.wav
.mp3
.aac
.aiff
.caf
Siendo el formato preferido el CAFF (Core Audio File Format, desarrollado por Apple).
Este tipo de fichero puede contener cualquiera de las codificaciones explicadas
anteriormente, aunque tambin ser preferible usar PCM (Little-Endian Integer 16-bit,
LEI16).
En caso de haber problemas de espacio, para conseguir una mejor optimizacin
podramos usar "AAC" para msica de fondo y "IMA4" para los efectos de sonido.
Para transformar de un formato a otro disponemos de herramientas como: afconvert,
afinfo, afplay.
afconvert -d [out data format] -f [out file format] [in file] [out file]

Por ejemplo, para transformar a PCM LEI16 empaquetado en CAFF usaremos:


afconvert -d LEI16 -f caff sonido.wav sonido.caf

13.3.2. Formatos de audio soportados en Android


En Android podemos reproducir ficheros de audio de diferentes tipos, tanto con
compresin como sin compresin:
AAC, HE-AACv1, HE-AACv2, empaquetados en ficheros de tipo: 3gp, mp4, m4a,
aac (3.1+), ts (3.0+)
AMR-NB, AMR-WB, empaquetados en ficheros de tipo: 3gp
Vorbis, empaquetado en ficheros de tipo: ogg, mkv (4.0+)
PCM, empaquetado en ficheros de tipo wav
FLAC (3.1+)
MP3
MIDI

13.4. Estndares de vdeo


El formato de vdeo indica el modo en que se guardan los datos de un archivo de vdeo
con el fin de que puedan ser interpretados por el ordenador. Existen varios formatos de
vdeo de gran implantacin: el QuickTime Movie (MOV), el AVI y el correspondiente al
estndar MPEG. El formato QuickTime Movie (MOV), creado por Apple, es
multiplataforma y en sus versiones ms recientes permite interactuar con pelculas en 3D

185

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

y realidad virtual. El AVI (Audio Video Interleaved, audio vdeo intercalado) es un


formato tambin multiplataforma. Tanto *.avi como *.mov son contenedores de audio y
vdeo con lo que son formatos de archivo. A este archivo habra que especificarle el tipo
de video o audio que est conteniendo y que puede ser sin compresin o con la
compresin soportada por dicho fichero como pueden ser para los *.avi el divx, Dv-pal,
etc. y para *.mov el sorenson, H.264, etc.
El formato correspondiente al estndar MPEG (Moving Pictures Experts Group) produce
una compresin de los datos con una pequea prdida de la calidad; desde su creacin, se
ha definido el MPEG-1, utilizado en CD-ROM y Vdeo CD, el MPEG-2, usado en los
DVD de Vdeo y la televisin digital, y el MPEG-4, que se emplea para transmitir vdeo e
imgenes en ancho de banda reducido; es un formato adecuado para distribuir multimedia
en la Web. El formato MPEG-4 es la base de actuales formatos como el divx, xvid o el
H.264, siendo este ltimo (H.264) un cdec tan potente que soporta vdeos de gran
formato y calidad excelente con anchos de banda muy reducidos.
El desarrollo de Internet ha propiciado formatos que permiten visualizar vdeos a travs
de la red, sin tener que descargar previamente el archivo completo; para esta finalidad, la
empresa RealNetworks ha establecido RealVideo y Microsoft su formato de vdeo
correspondiente al Windows Media Player (Reproductor de Windows Media), ambos con
gran futuro en el desarrollo de la distribucin de vdeo en tiempo real a travs de Internet.
Una empresa especializada en desarrollar tecnologas de compresin de vdeo es On2
Technologies, Inc., originalmente conocida como The Duck Corporation. Entre las
tecnologas de compresin de vdeo que desarrolla On2 se encuentran los cdec de vdeo
TrueMotion 1 y 2, y desde VP3 a VP8, los cuales han sido liberados como cdigo libre.
Todos ellos han sido diseados como alternativa a las tecnologas de vdeo de Windows
Media Video, RealVideo, MPEG-4 y H.264/MPEG-4 AVC. Existen varias compaas
entre las cuales estn Adobe (Macromedia), Apple Computer, RealNetworks, Skype y
AOL entre otros, que han elegido las tecnologas de compresin de vdeo de On2 debido
a que los cdecs ofrecen muy buena calidad de vdeo, la licencia cuesta menos y no
poseen complicadas cuotas de licencias de patentes.
Resumiendo, los estndares de vdeo que ms se utilizan actualmente son:
Conjunto de especificaciones MPEG-4
Parte 2 (Visual, implementado en DivX, Xvid), compatible con H.263
Parte 10 (MPEG-4 AVC, Advance Video Coding), igual que H.264
Parte 14 (Formato de fichero .mp4)

ITU-T serie H (Sistemas audiovisuales y multimedia)


H.263 (bajo bitrate para videoconferencia)
H.264 (alta calidad con menor bitrate)

On2Technologies
VP8 (formato de codificacin abierto)
Licencia Creative Commons

186

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

libvpx codifica en este formato (licencia BSD)


Formato .webm (Video VP8 + Audio Vorbis)

13.4.1. Formatos de vdeo en iOS


El sistema operativo iOS soporta ficheros de tipo mov, mp4, m4v y 3gp, y los siguientes
formatos de codificacin:
H.264, hasta 1.5 Mbps, 640x480, 30fps, versin de baja complejidad del H.264
Baseline Profile (no es estndar). Audio AAC-LC de hasta 160 Kbps, 48 kHz, stereo
H.264, hasta 768 Kbps, 320x240, 30fps, Baseline Profile hasta nivel 1.3. Audio
AAC-LC de hasta 160 Kbps, 48 kHz, stereo
MPEG-4, hasta 2.5 Mbps, 640x480, 30fps, Simple Profile. Audio AAC-LC de hasta
160 Kbps, 48 kHz, stereo
Sin embargo, los dispositivos modernos soportan mayores resoluciones, como:
iPhone 3G/3GS: 640x480
iPhone 4: 960x640
iPhone 5: 1136 x 640 px
iPad: 1024x768
iPad (4 generacin): 2048x1536
Para estos nuevos dispositivos los formatos de vdeo admitidos son:
H.264 hasta 720p, 30 fps, Main Profile nivel 3.1. Audio AAC-LC de hasta 160 Kbps,
48kHz, stereo (.m4v, .mp4, y .mov)
MPEG-4 hasta 2.5 Mbps, 640 x 480, 30 fps, Simple Profile. Audio AAC-LC de hasta
160 Kbps, 48kHz, stereo (.m4v, .mp4, y .mov)
Motion JPEG (M-JPEG) hasta 35 Mbps, 1280 x 720, 30 fps. Audio ulaw, PCM stereo
(.avi)
13.4.2. Formatos de vdeo en Android
En los dispositivos Android podremos utilizar cualquiera de los siguientes formatos de
vdeo:
H.263, empaquetados en ficheros de tipo: 3pg, mp4
H.264 / MPEG 4-AVC Baseline Profile, empaquetados en ficheros de tipo: 3gp, mp4,
ts (3.0+)
MPEG-4 SP (Simple Profile), empaquetados en ficheros de tipo: 3gp
VP8 (Android 2.3.3+), empaquetados en ficheros de tipo: webm, mkv (4.0+)

13.5. Perfiles de vdeo


Dependiendo de los dispositivos que queramos soportar y de la calidad de vdeo que estos

187

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

soporten podemos crear diferentes perfiles de formato de vdeo.


13.5.1. Perfil de vdeo general
La codificacin H.264 es soportada por la mayora de dispositivos. Por lo tanto, para
asegurarnos de que funcione en la mayor parte de smartphones, y en dispositivos iOS y
Android sin problemas, podemos usar para el vdeo:
H.264 Baseline Profile
Resolucin 480 x 320
Framerate mximo de 30 fps
Bitrate mximo de vdeo 1500 kbps
Y para el audio:
Audio AAC
Sample rate de audio 44100 kHz
Bitrate mximo de audio 128 kbps
13.5.2. Perfil de vdeo de alta calidad
Pero el perfil de vdeo anterior desaprovecha las caractersticas de dispositivos de ltima
generacin como las ltimas versiones de iPhone o iPad. Para aprovechar estos
dispositivos podemos crear otro perfil de alta calidad, usando para el vdeo:
Vdeo H.264 Baseline Profile
Resolucin 1280 x 720
Framerate mximo de 30 fps
Bitrate mximo de vdeo 5000 kbps
Y para el audio:
Audio AAC
Sample rate de audio 48000 kHz
Bitrate mximo de audio 160 kbps
13.5.3. Perfil de vdeo para dispositivos limitados
Si queremos extender el soporte a dispositivos antiguos, deberemos ofrecer tambin un
perfil de vdeo de menor complejidad que los anteriores:
Fichero 3GP, codificacin MPEG-4 (Parte 2)
Resolucin 176x144 - 320x240
Framerate mximo de 5-15 fps
Bitrate mximo de vdeo 52 - 192 kpbs
Y para el audio:

188

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Audio AAC-LC (Low Complexity)


Sample rate de audio 16000 kHz
Bitrate mximo de audio 16 - 24 kpbs

13.6. Descarga progresiva de vdeo


Nos referimos a una "descarga progresiva" cuando los archivos de vdeo se almacenan en
un servidor Web convencional (sin infraestructura adicional) y la descarga se realiza a
travs de HTTP o HTTPS. La descarga HTTP (progresiva) es el mtodo ms comn para
la transferencia de archivos en Internet: cuando visita una Web, todos los elementos que
la componen, textos e imgenes, se transfieren de esta manera. Una de las Webs ms
conocidas que utiliza este sistema es YouTube, adems las nuevas etiquetas para vdeo de
HTML 5 estn preparadas para este tipo de uso.
Cuando se solicita un vdeo de esta forma el servidor Web comienza a transferir la
totalidad del archivo, quedando almacenado temporalmente en el dispositivo local.
Adems, es posible visualizar el vdeo mientras se realiza esta descarga.
Las principales ventajas de este sistema es que solo se requiere un servidor Web
convencional y que una vez transferido el vdeo se puede visualizar desde cualquier punto
sin necesidad de volver a cargar o esperar. Pero tambin tiene desventajas importantes:
produce un mal uso del ancho de banda pues descarga todo el vdeo al principio usando
todo el ancho de banda disponible, cuando a lo mejor el usuario solo quiere visualizar una
parte de ste.
En Android slo podemos acceder al vdeo mediante el protocolo HTTP. Aunque a partir
de la versin 3.0 de Android ya se permite tambin el uso de HTTPS.
13.6.1. Preparacin para descarga progresiva
Para utilizar este tipo de reproduccin es necesario que el formato de los vdeos lo
soporte. Esto es debido a que el cliente debe poder obtener la informacin del vdeo antes
de iniciar la descarga o reproduccin. Para esto la cabecera del archivo debe de estar
codificada de forma que el formato se indique antes que el contenido. En la siguiente
imagen se muestra el esquema de codificacin de un vdeo (mov, mp4). En este caso, para
permitir la descarga progresiva, la seccin MOOV (con los metadatos del vdeo) debe ir
siempre antes que MDAT (con los datos de la pelcula), pero despus de FTYP.
El vdeo (mov, mp4) est dividido en tomos, donde:
ftyp: Formato de la pelcula.
moov: Contiene metadatos.
wide: Permite ampliar moov.
mdat: Contiene datos de la pelcula.

189

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En caso de que las cabeceras no estn en el orden correcto (pues hay aplicaciones que no
guardan los vdeos de esta forma), ser necesario modificar el vdeo para corregirlo. Esta
operacin se denomina Fast start, y existen muchas herramientas que nos pueden ayudar
a realizar este proceso:
QTIndexSwapper: Aplicacin Flash http://renaun.com/blog/code/qtindexswapper/
mp4-FastStart: Aplicacin para Windows http://www.datagoround.com/lab/
QuickTime: http://support.apple.com/kb/HT2438
QTFastStart: Aplicacin Python https://github.com/danielgtaylor/qtfaststart
En la siguiente imagen se muestra un esquema de este proceso, en el que si intentamos
reproducir un archivo con un formato incorrecto nos aparecer un aviso indicando que se
tiene que descargar todo el vdeo antes de la reproduccin. Por lo que tendremos que
corregir las cabeceras de este archivo.

190

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13.6.2. Limitaciones de la descarga progresiva


Adems de las desventajas que ya se han comentado (como el mal uso del ancho de
banda) existen otras referentes a restricciones impuestas por Apple para la publicacin en
la App Store. Pues no nos va a permitir descargar:
Vdeos de ms de 10 minutos
Vdeos de ms de 5Mb
En estos casos ser necesario utilizar el protocolo de transmisin streaming (actualmente
el sistema aceptado por Apple es el HTTP Live Streaming), adems este mismo protocolo
es el utilizado para las transmisiones en directo.

13.7. Streaming de vdeo


El streaming es la distribucin de multimedia a travs de una red de computadoras de
manera que el usuario consume el producto al mismo tiempo que se descarga. La palabra
streaming se refiere a que se trata de una corriente continua (sin interrupcin). Este tipo
de tecnologa funciona mediante un bfer de datos que va almacenando lo que se va
descargando para luego mostrarse al usuario. Esto se contrapone al mecanismo de
descarga de archivos, que requiere que el usuario descargue los archivos por completo
para poder acceder a ellos. El trmino se aplica habitualmente a la difusin de audio o
vdeo, siendo el protocolo principal usado para la transmisin de televisin y radio por

191

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Internet.
Este protocolo tiene varias ventajas frente a la descarga progresiva:
Se puede comenzar la reproduccin en cualquier punto de un vdeo sin necesidad de
esperar a que se descargue todo el contenido. La reproduccin es prcticamente
inmediata.
Ahorro de ancho de banda pues slo se transfiere (descarga) el fragmento de vdeo
que visionan los usuarios (ms un pequeo "buffer").
Ms proteccin para los vdeos, porque el archivo de vdeo no se almacena en el
ordenador de los usuarios; por lo tanto, resulta ms difcil de copiar.
El protocolo recomendado actualmente para el streaming de vdeo es el HTTP Live
Streaming. Este protocolo est soportado por los dispositivos iOS y Android a partir de la
versin 3.0 (slo ficheros MPEG-2 TS). Para versiones anteriores de Android podemos
utilizar RTSP (RTP, SDP).
13.7.1. Streaming RTSP
El protocolo de flujo en tiempo real (del ingls Real Time Streaming Protocol) establece
y controla uno o muchos flujos sincronizados de datos, ya sean de audio o de vdeo.
RTSP es un protocolo no orientado a conexin, en lugar de esto el servidor mantiene una
sesin asociada a un identificador, en la mayora de los casos RTSP usa TCP para datos
de control del reproductor y UDP para los datos de audio y vdeo aunque tambin puede
usar TCP en caso de que sea necesario.
La aplicacin VLC nos facilita la creacin de un servidor de streaming con RTSP. En la
siguiente imagen se muestra una captura de las opciones de configuracin necesarias de
esta aplicacin.

192

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Para
ms
informacin
consultar
http://www.videolan.org/doc/streaming-howto/en/ch04.html.

la

direccin

13.7.2. HTTP Live Streaming (HLS)


HTTP Live Streaming (tambin conocido como HLS) es un protocolo de comunicacin
desarrollado por Apple para el streaming de contenidos multimedia basado en HTTP. Su
funcionamiento se basa en la segmentacin del contenido en pequeos ficheros o trozos a
transmitir. Estos segmentos se descargan utilizando el protocolo HTTP. Segn se
reproduce el contenido, y dependiendo de la conexin, el cliente puede seleccionar
modificar el bitrate de los archivos descargados (simplemente seleccionando el siguiente
segmento con una compresin diferente). El primer fichero a transmitir es el playlist (un
fichero con extensin m3u8) con los metadatos de la transmisin, como nmero de
segmentos, bitrates disponibles, etc.
Dado que HLS funciona utilizando el protocolo estndar HTTP, no tiene problemas para
atravesar firewalls o servidores proxy. Esto no es as en otros protocolos basados en UDP,
como por ejemplo RTP. Este protocolo es adecuado para su utilizacin en emisiones en
directo o para vdeo bajo demanda (VOD, usado en la televisin por Internet).
Para crear un servidor HLS se puede utilizar un servidor web ordinario, lo nico que
necesitamos es proceso previo del vdeo o audio para realizar su codificacin y
segmentacin. En la siguiente imagen se muestra un esquema tpico de un servidor HLS.

193

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13.7.3. Ficheros del stream


Como ya se ha explicado, el protocolo HLS se basa en la segmentacin del contenido en
pequeos paquetes y en la generacin de un fichero de ndice denominado playlist con
extensin ".m3u8" que contendr las referencias a los segmentos que lo componen.
Cada uno de los segmentos se almacena en un fichero con extensin ".ts" que ser
referenciado mediante el fichero de ndice. El playlist puede ser actualizado cuando se
aaden nuevos segmentos. Adems los segmentos pueden sobrescribirse para permitir
emisiones en directo utilizando nicamente un nmero de segmentos fijo.
A continuacin se incluye un ejemplo de un fichero de ndice con 3 segmentos de 10
segundos de duracin:
#EXTM3U
#EXT-X-TARGETDURATION:10
#EXT-X-MEDIA-SEQUENCE:1
#EXTINF:10,
http://media.example.com/segment0.ts
#EXTINF:10,
http://media.example.com/segment1.ts
#EXTINF:10,
http://media.example.com/segment2.ts
#EXT-X-ENDLIST

La codificacin de los ficheros de segmentos ".ts" se realiza utilizando:


MPEG-2 Transport Stream
Vdeo H.264
Audio AAC
Para segmentar un vdeo disponemos de varias herramientas. Por ejemplo, en Mac
podemos utilizar "mediafilesegmenter" para trocear un fichero de vdeo o
"mediastreamsegmenter" para crear los segmentos a partir de un flujo de datos. En
Linux podemos realizar la misma operacin utilizando "ffmpeg" o "mpgtx".

194

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13.8. Audio y vdeo en HTML 5


Una de las caractersticas ms importantes que se han incorporado en HTML 5 es el
soporte para la reproduccin de audio y vdeo directamente con etiquetas HTML. Es
decir, no es necesario utilizar un reproductor flash como hasta ahora. El nico problema
es que al ser una caracterstica nueva solamente es soportado por las ltimas versiones de
los navegadores y adems existen algunas diferencias entre ellos. En las siguientes
secciones se explica el funcionamiento de estas nuevas etiquetas.
13.8.1. Audio
El nuevo elemento audio permite insertar archivos sonoros en diferentes formatos,
incluyendo mp3 y ogg. Adems provee de una interfaz de control sobre la reproduccin
del mismo con una API en JavaScript sin necesidad de plugins de ningn tipo (como
Flash). Aadir un reproductor de audio en HTML5 es muy simple:
<audio src="archivo.mp3" controls>
<p>Tu navegador no soporta el elemento audio</p>
</audio>

En Firefox obtendramos un resultado similar a:

El texto que se encuentra entre las etiquetas "audio" solo es tenido en cuenta por
navegadores que no soporten la nueva etiqueta. El atributo controls indica al navegador
que muestre los controles de reproduccin. En caso de no activarlo no se visualizara
nada, pero podramos controlar la reproduccin mediante funciones JavaScript, de la
forma:
<audio id="player" src="archivo.mp3"></audio>
<button
onclick="document.getElementById(player).play();">Reproducir</button>
<button
onclick="document.getElementById(player).pause();">Pausa</button>
<button onclick="document.getElementById(player).volume += 0.1;">Subir
Volumen</button>
<button onclick="document.getElementById(player).volume -= 0.1;">Bajar
Volumen</button>

Tambin podemos usar los atributos autoplay y loop para que se auto-reproduzca y
para que se cree un bucle de reproduccin infinito.
<audio src="archivo.mp3" autoplay loop></audio>

El formato de audio a utilizar vendr impuesto por el navegador usado y no por el


195

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

estndar:
Cdec

IE>=9

Firefox

Chrome

Safari

Opera

Ogg Vorbis

no

no

WAV PCM

no

MP3

no

AAC

no

Speex

no

no

no

no

Como puede verse, combinando Vorbis y MP3 podremos ofrecer audio a todos los
navegadores mayoritarios. Existe una forma de definir ms de un archivo de audio para la
etiqueta "audio", en lugar de usar el atributo src, utilizaremos la etiqueta source para
poder definir mltiples archivos. Estas etiquetas se irn leyendo de arriba a abajo hasta
que el navegador encuentre un formato soportado. De esta manera podremos dar soporte a
todos los navegadores.
<audio controls>
<source src="archivo.ogg" type="audio/ogg" />
<source src="archivo.mp3" type="audio/mpeg" />
<object type="application/x-shockwave-flash"
data="player.swf?soundFile=archivo.mp3">
<param name="movie" value="player.swf?soundFile=archivo.mp3" />
<a href="archivo.mp3">Descarga el archivo de audio</a>
</object>
</audio>

En este ejemplo hemos aadido adems una tercera lnea con un reproductor Flash por si
no fuesen soportados ninguno de los formatos anteriores, y un link directo de descarga
para aquellos que tampoco soporten Flash. As estaremos ofreciendo nuestro contenido a
todos los navegadores y dispositivos manteniendo unas buenas prcticas en cuanto a
accesibilidad del contenido se refiere.
13.8.2. Vdeo
La nueva especificacin de HTML5 soporta la inclusin de vdeo en las pginas web de
forma nativa. La etiqueta "video" no especifica el formato del mismo sino que el uso de
uno u otro vendr impuesto por el fabricante del navegador:
Cdec

IE>=9

Firefox

Chrome

Safari

Opera

Ogg Theora

no

no

H.264

no

no

no

VP8

no

no

El elemento "video" dispone de los atributos autoplay, loop y preload, para activar

196

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

la auto-reproduccin, para indicar que se reproduzca en bucle y para activar/desactivar la


precarga del vdeo. Asimismo puedes utilizar los controles que te ofrece el navegador de
forma nativa utilizando el atributo "controls" o bien puedes ofrecer tus propios controles
en JavaScript (de forma similar a como lo vimos en la seccin anterior). Dado que el
vdeo ocupa un espacio, tambin podremos definir sus dimensiones con los atributos
width y height. E incluso podemos indicar una imagen para que se muestre antes de
la reproduccin mediante el atributo poster:
<video src="archivo.mp4" controls width="360" height="240"
poster="poster.jpg"> </video>

Con lo que obtendramos un resultado similar a:

Al igual que con la etiqueta audio, para dar soporte a todos los navegadores podemos
especificar diferentes fuentes de vdeo con distintos formatos. Tambin podemos aadir el
plugin de Flash a travs de la etiqueta object e incluso incluir un link de descarga, por si
ninguno de los formatos anteriores fuese compatible. A continuacin se incluye un
ejemplo:
<video controls width="360" height="240" poster="poster.jpg">
<source src="archivo.ogv" type="video/ogg" />
<source src="archivo.mp4" type="video/mp4" />
<object type="application/x-shockwave-flash" width="360" height="240"
data="player.swf?file=archivo.mp4">
<param name="movie" value="player.swf?file=archivo.mp4" />
<a href="archivo.mp4">Descarga la pelcula</a>
</object>
</video>

13.8.2.1. HLS en HTML5

La nueva etiqueta "video" de HTML 5 tambin soporta la reproduccin de vdeo


utilizando el protocolo HLS. Para esto simplemente tenemos que indicar el fichero de
ndice (.m3u8) en el atributo "src" de la etiqueta. A continuacin se muestra un cdigo de
ejemplo:

197

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<video
src="http://localhost/~usuario/indice.m3u8"
controls></video>

13.9. Audio y Vdeo en Sencha touch


La API de Sencha Touch proporciona funcionalidad para controlar elementos de audio y
vdeo. Sin embargo, en realidad realiza una conversin a las etiquetas nativas de HTML 5
y genera cdigo javascript para su control (a travs de su API).
Estos componentes se pueden aadir como "items" de un panel, por ejemplo, para el
elemento vdeo:
var pnl = new Ext.Panel({
fullscreen: true,
items: [
{
xtype
: 'video',
width
: 175,
height
: 98,
url
: "videofile.mov",
posterUrl: 'imagefile.png'
}
]
});

Donde "url" es la direccin del vdeo y "posterUrl" una imagen opcional que se mostrar
antes de la visualizacin. El cdigo para el componente de "audio" sera el siguiente:
var pnl = new Ext.Panel({
fullscreen: true,
items: [
{
xtype: 'audio',
url : "audiofile.mp3"
}
]
});

En la API de Sencha Touch se puede encontra mucha ms informacin, como el resto de


mtodos que podemos utilizar para el control de estos elementos, en las siguientes
tenemos disponible toda esta informacin:
http://docs.sencha.com/touch/1-1/#!/api/Ext.Video
http://docs.sencha.com/touch/1-1/#!/api/Ext.Audio

13.10. Audio y Vdeo en JQuery Mobile


En JQuery Mobile podemos utilizar directamente las nuevas etiquetas de "audio" y
"video" disponibles en HTML 5.

198

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13.11. Repositorios de vdeos


Existen servicios que nos permiten alojar vdeos en un repositorio y posteriormente
acceder a ellos desde nuestras aplicaciones, como por ejemplo: YouTube o Zencoder.
13.11.1. Plataforma YouTube
Podemos aprovechar la plataforma YouTube para subir vdeos y acceder a ellos desde
nuestras aplicaciones, ya sea desde una pgina Web o desde una aplicacin Web para
mvil. En este segundo caso nos tenemos que asegurar de activar la opcin "Hacer que
este vdeo est disponible en telfonos mviles y en TV" en la seccin de
"Configuracin" del vdeo que hayamos subido. En la siguiente imagen se muestra una
captura de esta opcin:

Para utilizar un vdeo de YouTube en una pgina Web (ya sea un vdeo que hemos subido
nosotros o cualquier otro) podemos obtener el cdigo HTML desde las opciones que
aparecen debajo del propio vdeo: apretamos sobre el botn "Share" para mostrar las
opciones de compartir, y elegimos la opcin "Embed", que nos mostrar el cdigo HTML
que tenemos que aadir a nuestra Web. Este cdigo utiliza la etiqueta "iframe" para
insertar el vdeo, de la forma:
<iframe
src="http://www.youtube.com/embed/VIDEO_ID"
width="320"
height="190"></iframe>

donde "VIDEO_ID" ser el identificador del propio vdeo, por ejemplo:


<iframe
src="http://www.youtube.com/watch?v=IExxe_hg9jg"
width="320"
height="240"></iframe>

Si lo reproducimos en una aplicacin web para mvil obtendramos un resultado similar


al siguiente:

199

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

13.11.2. Zencoder
Otro ejemplo de repositorio de vdeos es Zencoder (http://zencoder.com). La filosofa de
esta herramienta es diferente, nos permite subir vdeos que se almacenarn y codificarn
automticamente en mltiples formatos para su acceso. Adems da soporte de acceso para
todo tipo de dispositivos y permite realizar streaming de los vdeos.

13.12. Podcast
El podcasting consiste en la distribucin de archivos multimedia (normalmente audio o
vdeo, que puede incluir texto como subttulos y notas) mediante un sistema de redifusin
(RSS) que permita suscribirse y usar un programa que lo descarga para que el usuario lo
escuche en el momento que quiera.
El trmino podcast surge como contraccin de iPod y broadcast (transmisin).
Inicialmente se refera a las emisiones de audio, pero posteriormente se ha usado de
forma comn para referirse a emisiones multimedia, de vdeo y/o audio, audiolibros o
incluso documentos.
El contenido de estos podcast debe de estar disponible para la sincronizacin con el
dispositivo mediante diferentes medios:
Descarga directa (por cable, wifi o a travs de la red mvil).
Suscripcin para la descarga automtica cuando hayan nuevos captulos disponibles.
Reproduccin online sin necesidad de descarga.
Adems estos podcast se pueden publicar en diferentes formatos, dependiendo de su tipo:
Audio:
.m4a (audio/x-m4a)
.mp3 (audio/mpeg)

Vdeo:

200

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

.mov (video/quicktime)
.mp4 (video/mp4)
.m4v (video/x-m4v)

Libros y documentos:
.pdf (application/pdf)
.epub (document/x-epub)

13.12.1. RSS feed


La suscripcin a un podcast se realiza a travs de una fuente RSS, el cual nos permite
difundir la informacin actualizada a los usuarios. RSS son las siglas de Really Simple
Syndication, un formato XML para indicar o compartir contenido en la web. El formato
permite distribuir contenidos a travs del navegador o utilizando un software diseado
para leer estos contenidos RSS.
Las etiquetas principales del documento XML del RSS son: "rss" que ser la etiqueta
contenedora global, "channel" que indicar el canal de distribucin, y una etiqueta "item"
por cada uno de los episodios. A continuacin se incluye un ejemplo de una estructura
bsica:
<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd"
version="2.0">
<channel>
<!-- Informacion del canal -->
<item>
<!-- Informacion del item -->
</item>
<item>
<!-- Informacion del item -->
</item>
...
</channel>
</rss>

El podcast se define como un canal (channel), el cuan deber contener al menos las
etiquetas "title", "link" y "description". Adems de una serie de etiquetas opcionales con
informacin de idioma, autor, etc.
<title>Servicios Multimedia para Dispositivos Mviles</title>
<link>http://jtech.ua.es/podcast/index.html</link>
<language>en-us</language>
<copyright>&#x2117; &amp; &#xA9; 2012 Miguel ngel Lozano</copyright>
<itunes:subtitle>Podcast sobre dispositivos mviles</itunes:subtitle>
<itunes:author>Miguel ngel Lozano</itunes:author>
<itunes:summary>Resumen</itunes:summary>
<description>Descripcin</description>
<itunes:owner>

201

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<itunes:name>Miguel ngel Lozano</itunes:name>


<itunes:email>[email protected]</itunes:email>
</itunes:owner><itunes:image href="http://jtech.ua.es/podcast/ios.jpg" />
<itunes:category text="Technology">
<itunes:category text="Gadgets"/>
</itunes:category>
<itunes:category text="TV &amp; Film"/>

El canal contiene varios episodios (items), cuyas etiquetas bsicas son "title", "link" y
"description". Para aadir nuevos episodios simplemente tenemos que aadir un nuemo
elemento "item" a la lista.
<item>
<title>Episodio 1</title>
<itunes:author>Miguel ngel Lozano</itunes:author>
<itunes:subtitle>Caractersticas de los dispositivos</itunes:subtitle>
<itunes:summary>
Redes de telefona mvil. Tipos de dispositivos. Plataformas de
desarrollo
</itunes:summary>
<itunes:image
href="http://www.jtech.ua.es/images/logo-especialista-moviles_mini.png" />
<enclosure url="http://localhost/~malozano/episodio1.mp3"
length="169608456" type="audio/mpeg" />
<guid>http://localhost/~malozano/episodio1.mp3</guid>
<pubDate>Mon, 5 Mar 2012 19:00:00 GMT</pubDate>
<itunes:duration>1:28:20</itunes:duration>
<itunes:keywords>dispositivos, moviles, redes,
desarrollo</itunes:keywords>
</item>

En
las
direcciones
http://www.apple.com/itunes/podcasts/specs.html
y
http://www.w3schools.com/rss/rss_item.asp podemos encontrar mucha ms informacin
sobre como generar un podcast y distribuirlo.
13.12.2. Subscripcin a un podcast
Existen multitud de herramientas que permiten la suscripcin a un podcast, por ejemplo a
travs de web algunas de las ms conocidas son: Google Reader, Bloglines, MyYahoo!,
Netvibes, o FeedReader.
Pero tambin podemos utilizar aplicaciones de escritorio, como iTunes (usando la opcin
"Avanzado > Suscribirse a un podcast ...") o la nueva aplicacin de iOS llamada
"podcast".

202

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En Android podemos utilizar Google Listen. A continuacin se muestran algunas capturas


de esta herramienta:

13.12.3. Publicacin de un podcast


Existen multitud de pginas para la publicacin de podcast, esto depender de la temtica
del mismo. Por ejemplo, en Espaa algunas de las ms famosas son ivoox o los podcast
de rtve.es, que nos permiten escuchar de forma offline los programas de radio adems de
suscribirnos.
Pero una de las fuentes ms famosas y utilizadas es la App Store, donde podemos solicitar
la publicacin de un podcast. Para esto, utilizando nuestra cuenta de iTunes, deberemos
entrar en la iTunes Store, en la seccin de Podcast, y pulsar sobre "Enviar un podcast".

203

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

14. Ejercicios - Multimedia


A continuacin se incluyen algunos ejercicios para que puedas practicar con los
contenidos vistos en esta sesin. Puedes descargar las plantillas para los ejercicios desde
sesion07-ejercicios.zip.

14.1. Ejercicio - Audio y vdeo en HTML (1 punto)


En este ejercicio vamos a probar las nuevas etiquetas de HTML 5 de audio y vdeo,
adems de la reproduccin de HLS y de vdeos de YouTube. Para esto vamos a crear un
pequeo ejemplo de cada uno en un fichero llamado "html_audio_video.html". Para cada
ejemplo incluye en el HTML una cabecera indicando la forma de reproduccin.
Creamos un elemento audio con los controles activados, y le indicamos que cargue en
primer lugar el archivo "media/audio.ogg", en caso de que no soporte este formato que lo
intente con "media/audio.mp3", seguido del reproductor flash (usando
"media/audio.mp3") y el enlace para descarga directa del archivo mp3.
Para el elemento vdeo activaremos el uso de los controles, de la precarga y el autobuffer.
Le indicaremos que en primer lugar utilice el archivo "media/video.ogv", y que en caso
de no soportarlo intente utilizar "media/video.mp4", seguido por el reproductor en flash
(usando "media/video.mp4") y la descarga directa del archivo mp4.
A continuacin incluimos otra etiqueta de vdeo para probar la reproduccin utilizando el
protocolo HLS. En el directorio "media" tenemos un fichero de vdeo ya segmentado,
cuyo ndice se llama "indice.m3u8". Si quieres probar a segmentar un vdeo puedes
utilizar la aplicacin mediafilesegmenter.
Por ltimo vamos a incluir un vdeo de YouTube. Accede a la direccin
http://www.youtube.com/watch?v=CBWQLJX66QI y obtn el cdigo HTML que nos
permitir insertarlo en nuestra web.

14.2. Ejercicio - Vdeo en JQuery Mobile y Sencha Touch (0.6 puntos)


En este ejercicio vamos a probar la reproduccin de vdeo en los frameworks de
desarrollo web para mvil Sencha Touch y JQuery Mobile. En las plantillas se incluyen
dos ficheros HTML llamados "jqmobile.html" y "senchaTouch.html" con la estructura
bsica. Completa el cdigo para que reproduzcan el vdeo "media/video.ogv".

14.3. Ejercicio - Cabecera MOOV (0.6 puntos)


En este ejercicio vamos a practicar con la descarga progresiva de vdeo. Abre un
emulador de Android con la versin 1.6 y reproduce el vdeo "video.mp4" incluido en las

204

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

plantillas de los ejercicios. Para poder acceder a este vdeo tendrs que colocarlo en un
servidor Web, en caso de no disponer puedes acceder directamente a la direccin:
http://jtech.ua.es/dadm/video.mp4.
Se ha reproducido correctamente el vdeo? De no ser as es posible que el vdeo no est
preparado para la descarga progresiva. Para solucionar este problema podemos utilizar la
herramienta QTIndexSwapper para arreglar las cabeceras.
Una vez corregido el vdeo vuelve a probar su reproduccin en el emulador de Android.
Si no dispones de un servidor Web puedes probar el vdeo corregido accediendo a la
direccin: http://jtech.ua.es/dadm/video_qtp.mp4.

14.4. Ejercicio - Podcast (0.8 puntos)


En este ejercicio vamos a practicar con los conceptos vistos en la seccin de Podcast. Para
esto vamos a crear un "feed" de ejemplo que permita la suscripcin a un podcast. En las
plantillas se incluye un archivo "feed.rss" con la estructura bsica que debe tener este
RSS, y en la carpeta "media" puedes encontrar dos archivos MP3 (episodio1.mp3 y
episodio2.mp3) que utilizaremos como contenido de audio para los captulos de nuestro
podcast.
Completa el archivo "feed.rss" con la informacin del canal y del primer item. Abre
iTunes y aade una suscripcin a el podcast que acabas de crear. Para esto ser necesario
que los archivos estn en la carpeta de servidor Web (~/Sites en Mac) y que accedamos a
nuestro feed desde iTunes usando la direccin: "http://localhost/~user/". En caso de que el
servidor no est activado tenemos que ir a: "Preferencias Sistema -> Compartir ->
Compartir Web" y activarlo.
Comprueba la informacin que muestra iTunes del podcast y el primer episodio. Si todo
est correcto, vuelve a abrir el fichero "feed.rss" y aade el segundo episodio. Actualiza y
comprueba desde iTunes que aparece.

205

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

15. PhoneGap
15.1. Introduccin
PhoneGap es un framework de cdigo abierto para el desarrollo de aplicaciones para
mviles. Su principal caracterstica es ser multiplataforma, es decir, con un solo cdigo de
aplicacin podemos utilizarlo en multitud de plataformas mviles, como Android, iOS o
Windows Phone.

Inicialmente PhoneGap fue desarrollado por Nitobi bajo licencia de software libre, pero
en Octubre de 2011 Adobe anunci oficialmente la adquisicin de Nitobi, pasando as
PhoneGap al control del gigante del software. Esto gener una gran incertidumbre entre
los desarrolladores, pues el framework poda pasar a ser una tecnologa propietaria, pero
en una genial estrategia, Adobe don PhoneGap a la fundacin Apache, conservando de
esta forma la integridad libre de PhoneGap.
En la actualidad, el proyecto en el sitio web de la fundacin Apache esta nombrado como:
"Apache Cordova", pero PhoneGap sigue siendo una especie de marca comercial, por lo
que an se sigue usando ese nombre para identificar al popular framework.
El ncleo de las aplicaciones PhoneGap se crea utilizando lenguajes de programacin
Web, como JavaScript, HTML5, CSS3, y con la ayuda de otros frameworks de desarrollo
y de la propia API de PhoneGap. Esta API nos permite acceder mediante cdigo
JavaScript a caractersticas nativas del mvil, como por ejemplo: Acelermetro, cmara,
contactos, eventos, geolocalizacin, redes o almacenamiento. Posteriormente, y para cada
una de las plataformas mviles para las que queramos generar nuestra aplicacin,
tendremos que incluir este ncleo Web como parte de la aplicacin nativa. De esta forma
podremos generar una aplicacin "nativa" para cada plataforma mvil aprovechando para
todas ellas el mismo ncleo de la aplicacin.
Las aplicaciones desarrolladas con PhoneGap se consideran aplicaciones hbridas. Una
aplicacin es hbrida cuando es una aplicacin nativa con una capa intermedia de
herramientas que hacen uso de otros lenguajes de programacin. Por el contrario se
considera nativa cuando ha sido desarrollada ntegramente utilizando la API y lenguaje de
programacin que proporciona la compaa que vende el producto. Esta tcnica de
programacin tiene varias ventajas: el usuario sentir que la aplicacin es parte del

206

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

sistema operativo, nos permitir distribuir la aplicacin como una aplicacin nativa, y
adems nos ahorrar muchsimo trabajo.
Puedes encontrar ms informacin de PhoneGap en la direccin www.phonegap.com,
donde podrs descargar la ltima versin del framework.

15.2. Soporte
Con PhoneGap es posible desarrollar aplicaciones para los siguientes sistemas operativos
para mviles:
Android
iOS
Windows Phone
BlackBerry OS
Web OS
Symbiam
Bada
Para el desarrollo de la aplicacin, adems de poder utilizar lenguajes de programacin
web HTML 5, CSS 3 y JavaScript, tambin soporta perfectamente el uso de frameworks
de desarrollo web mvil como: jQuery Mobile, Sencha Touch, Dojo, jQTouch,
SprountCore, GloveBox, XUI, iScroll, entre otros.
En la siguiente tabla se muestra la disponibilidad de las diferentes caractersticas nativas y
hardware a las que nos da acceso la API de PhoneGap en cada uno de los sistemas
operativos para mviles:
iPhone
/
iPhone
3G

iPhone
3GS
and
newer

Android

BlackberryBlackberryWebOS Windows Symbian Bada


OS 5.x OS
Phone
6.0+
7

Acelermetro
#

Cmara #

Brjula

Contactos#

Ficheros #

Geolocalizacin
#

Media

Red

Notificacin
#
(Alertas)

207

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Notificacin
#
(Sonido)

Notificacin
#
(Vibracin)

Almacenamiento
#

15.3. Cmo trabaja PhoneGap


El esquema bsico de funcionamiento de PhoneGap es el siguiente:
1. Construir la aplicacin usando estndares Web: HTML, HTML 5, CSS, CSS3,
JavaScript o haciendo uso de otros frameworks para el desarrollo de aplicaciones
Web.
2. Combinar la aplicacin Web con PhoneGap, esto nos dar acceso a las caractersticas
nativas de los dispositivos mviles.
3. Configurar la aplicacin en cada una de las plataformas para las que queramos
generar la aplicacin nativa.
Es importante utilizar estndares web para que nuestra aplicacin funcione en la mayora
de dispositivos mviles.

15.4. Configuracin
Al descargar PhoneGap de su sitio web (www.phonegap.com) obtenemos un archivo
".zip", el cual contiene una carpeta de recursos para cada sistema operativo. En cada
carpeta encontraremos una librera JavaScript y otra en el lenguaje nativo que usa la
plataforma.
Por ejemplo, para Android tendremos una librera escrita en JavaScript, usada para el
desarrollo de las aplicaciones web, que nos dar acceso al hardware del dispositivo a
travs de la API de PhoneGap. Adems tendremos una librera escrita en Java que realiza
la comunicacin o puente entre la API JavaScript y las caractersticas nativas del sistema
operativo o hardware.
La configuracin de PhoneGap se realiza de forma diferente para cada sistema operativo
mvil, pues se utilizan diferentes IDEs de desarrollo, distintos lenguajes de programacin
(nativos) y la inclusin del cdigo de nuestra aplicacin Web segn la plataforma tiene
tambin sus particularidades.
En la siguiente seccin explicaremos la configuracin de PhoneGap para Android, por
ltimo daremos un listado de enlaces con tutoriales para la configuracin en el resto de
sistemas.

15.5. Configuracin con Android

208

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

En esta seccin vamos a ver como configurar PhoneGap para el entorno de desarrollo de
Android. Adems crearemos una primera aplicacin de ejemplo.
Para preparar el entorno de desarrollo, deberemos hacer lo siguiente:
Descargar e instalar Eclipse.
Descargar e instalar el SDK de Android.
Instalar el plugin ADT (Android Development Tools) desde el gestor de plugins de
Eclipse.
Descargar y decomprimir PhoneGap (Cordova). En este caso utilizaremos solamente
el directorio de Android.
Para configurar un nuevo proyecto tenemos dos posibles opciones: utilizar el script
create que facilita PhoneGap (solo est disponible en la ltima versin y todava genera
algunos errores), o crear un nuevo proyecto desde Eclipse y configurarlo manualmente. A
continuacin veremos en detalle estas dos opciones.
15.5.1. Configuracin desde un terminal
Abre un terminal y entra en la carpeta "lib/android/bin". En esta carpeta podemos
encontrar el script create para diferentes sistemas operativos. Este script genera un
nuevo proyecto PhoneGap para Eclipse a partir de los siguientes parmetros:
./create <project_folder_path> <package_name> <project_name>

Donde:
project_folder_path: es el path donde se crear el nuevo proyecto.
package_name: es el nombre del paquete que encapsular el cdigo de nuestra
aplicacin. Normalmente se suele utilizar el nombre inverso de dominio de la
organizacin, pero aadiendo el nombre de la aplicacin. Por ejemplo:
"es.ua.jtech.ejemploPhoneGap". Este nombre no puede contener espacios ni nmeros
despus de un punto.
project_name: es el nombre del proyecto que se generar en Eclipse. Este nombre no
puede contener espacios y debe de empezar con maysculas. Por ejemplo, podramos
utilizar: EjemploPhoneGap
Adems, antes de ejecutar este script deberemos incorporar al PATH del sistema la ruta
del SDK de Android. Si por ejemplo estamos en Linux y nuestro SDK est en la ruta
"/home/javi/Code/android-sdks", aadiremos al ".bash_profile" la siguiente lnea:
export PATH=${PATH}:/home/javi/Code/android-sdks/platform-tools
:/home/javi/Code/android-sdks/tools

Una vez creado el proyecto abriremos Eclipse y lo importaremos utilizando la opcin:


"File -> New -> Project...", y en la ventana que se abre elegiremos "Android -> Android
Project from Existing Code".

209

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

15.5.2. Configuracin desde Eclipse


Los pasos a seguir en este caso son los siguientes:
1. Ejecutar Eclipse y crear un nuevo proyecto Android (Android Application Project):

A continuacin seguiremos los pasos del asistente y rellenaremos todos los campos:
nombre de la aplicacin, nombre del proyecto, paquete, generaremos un icono
adecuado, y una actividad en blanco. Para esta actividad podremos indicar el nombre
que queramos, pero nos tendremos que asegurar que no herede de ninguna clase
(Hierarchical Parent).
Una vez realizados todos estos pasos apretaremos a finalizar.
2. En el directorio raz del proyecto crearemos dos nuevas carpetas:
libs (si no existe)
assets/www
3. Copia los siguientes ficheros y carpetas desde la carpeta descomprimida de PhoneGap
"/lib/android/" a la carpeta indicada de tu proyecto:
Copia "cordova-VERSION.js" a la carpeta "assets/www" de tu proyecto.
Copia "cordova-VERSION.jar" a la carpeta "/libs" de tu proyecto.
Copia la carpeta "xml" dentro de la carpeta "res" de tu proyecto.

210

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

4. Incorporamos la librera "cordova-VERSION.jar" que acabamos de aadir al "Java


Build Path" del proyecto. Para esto apretamos con el botn derecho del ratn encima
del nombre del proyecto y abrimos "Properties". En la seccin "Java Build Path",
dentro de la pestaa "Libraries", apretamos al botn "Add JARs..." y aadimos esta
librera (buscndola dentro del propio proyecto).

5. Editamos el fichero de cdigo Java de la actividad principal (dentro del directorio


"src", creado con cdigo por defecto al crear el proyecto), y realizamos los siguientes
cambios:
Aadimos el import org.apache.cordova.*;
Cambiamos la definicin de la clase para que herede de "DroidGap" en lugar de
"Activity".
Eliminamos la lnea setContentView()
Aadimos el siguiente cdigo dentro del mtodo "onCreate":
super.loadUrl("file:///android_asset/www/index.html");

211

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

6. Ahora tenemos que configurar correctamente el fichero "AndroidManifest.xml". Lo


abrimos y vamos a la ltima pestaa para visualizar el cdigo XML. Buscamos la
seccin <uses-sdk.../> y pegamos a continuacin (antes de la seccin
<application.../>) el siguiente cdigo:
<supports-screens
android:largeScreens="true"
android:normalScreens="true"
android:smallScreens="true"
android:resizeable="true"
android:anyDensity="true" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"
/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission
android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECEIVE_SMS" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS"
/>
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"
/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="android.permission.BROADCAST_STICKY" />

Con este cdigo estamos dando permisos para el acceso a todas las caractersticas
nativas y hardware del dispositivo. Es posible que en nuestra aplicacin no utilicemos
la mayora de ellas, por lo que tendremos que eliminarlas antes de distribuir nuestra
aplicacin.
Para aadir soporte a los cambios de orientacin adems tenemos que aadir el
siguiente cdigo como un atributo dentro de la etiqueta <activity>:
android:configChanges="orientation"

212

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Finalmente, nuestro fichero "AndroidManifest.xml" debera ser similar al siguiente:

7. Para probar que todo funciona correctamente vamos a crear un fichero HTML de
prueba llamado "index.html" dentro de la carpeta "assets/www" con el siguiente
contenido:
<!DOCTYPE HTML>
<html>
<head>
<title>Cordova</title>
<script type="text/javascript" charset="utf-8"
src="cordova-VERSION.js"></script>
</head>
<body>
<h1>Hello World</h1>
</body>

213

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

</html>

8. Ahora ya podemos probar nuestra aplicacin en el simulador: hacemos clic con el


botn derecho encima del nombre de proyecto y elegimos la opcin "Run As >
Android Application". Si ya tenamos creada una mquina virtual ejecutar nuestra
aplicacin en ella, en caso contrario nos indicar que tenemos que crearla.
9. Si queremos probarlo en un dispositivo real, nos tendremos que asegurar que el modo
de depuracin USB est activado en el dispositivo (Settings > Applications >
Development), y posteriormente conectarlo al sistema. La forma de ejecutar nuestra
aplicacin ser la misma: clic con el botn derecho encima del nombre de proyecto y
elegimos la opcin "Run As > Android Application".
Para ms informacin sobre la compilacin para un dispositivo real podemos
consultar la direccin: http://developer.android.com/tools/device.html.

15.6. Configuracin en otros sistemas


Para configurar PhoneGap con otros sistemas podemos consultar la gua de "Primeros
pasos con" : iOS, Blackberry, Symbian, WebOS, Windows Phone, Bada y Tizen, en la
siguiente direccin:
http://docs.phonegap.com/en/2.1.0/guide_getting-started_index.md.html

15.7. API de PhoneGap


En esta seccin vamos a ver algunas de las funciones que nos ofrece la API de PhoneGap
para el acceso a las caractersticas nativas y hardware del dispositivo, como por ejemplo
acceso a las notificaciones, informacin del dispositivo, conexin, acelermetro, brjula,
geolocalizacin o cmara. Adems, al final de esta seccin se incluyen indicaciones para
obtener ms informacin sobre las opciones que no se tratan.
En el siguiente cdigo de ejemplo se muestran los primeros pasos que tenemos que
realizar con PhoneGap. En primer lugar cargamos la API de PhoneGap desde su librera
JavaScript. A continuacin tenemos que esperar a que se cargue correctamente la librera
y los objetos generados que nos dan acceso a las funcionalidades del dispositivo:
<!DOCTYPE html>
<html>
<head>
<title>Ejemplo de uso de PhoneGap</title>
<script type="text/javascript" charset="utf-8"
src="cordova-2.2.0.js"></script>
<script type="text/javascript" charset="utf-8">
// Esperamos a que cargue
document.addEventListener("deviceready", onDeviceReady, false);
// Cordova est listo
function onDeviceReady() {
navigator.FUNCION( PARAMETROS );
}

214

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

// Otras funciones...
function funcionEjemplo() {
navigator.FUNCION( PARAMETROS );
}
</script>
</head>
<body>
<p><a href="#" onclick="funcionEjemplo(); return false;">Lanzar
funcin</a></p>
</body>
</html>

15.7.1. Notificaciones
Permite mostrar notificaciones visuales, o mediante sonido o vibracin. Para esto
disponemos de los siguientes mtodos:
notification.alert: muestra un mensaje visual de aviso
navigator.notification.alert(message, alertCallback, [title],
[buttonName])

donde:
message: Cadena con el mensaje a mostrar en el cuadro de dilogo.
alertCallback: Nombre de la funcin que se llamar cuando se cierre el aviso.
title: Cadena con el ttulo del cuadro de dilogo (Opcional, por defecto: "Alert")
buttonName: Cadena con el texto del botn (Opcional, por defecto: "OK")

notification.confirm: muestra un cuadro de dilogo de confirmacin.


navigator.notification.confirm(message, confirmCallback, [title],
[buttonLabels])

donde:
message: Cadena con el mensaje a mostrar en el cuadro de dilogo.
confirmCallback: Nombre de la funcin que se llamar cuando se cierre el aviso.
Esta funcin recibe un parmetro con el ndice del botn presionado.
title: Cadena con el ttulo del cuadro de dilogo (Opcional, por defecto:
"Confirm")
buttonLabels: Lista de cadenas separadas por comas con los textos de los botones
(Opcional, por defecto: "OK,Cancel")

notification.beep: Reproduce un sonido tipo "beep" un nmero de veces


especificado.
navigator.notification.beep(times);

donde "times" indica el nmero de veces a repetir el sonido.


notification.vibrate: Realiza una vibracin en el dispositivo durante un tiempo
especificado.
navigator.notification.vibrate(milliseconds)

215

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

donde "time" indica el tiempo en milisegundos de la vibracin.


A continuacin se incluye un ejemplo completo de uso de todas estas funciones:
<!DOCTYPE html>
<html>
<head>
<title>Ejemplo de Notificaciones</title>
<script type="text/javascript" charset="utf-8"
src="cordova-2.2.0.js"></script>
<script type="text/javascript" charset="utf-8">
// Esperamos a que cargue
document.addEventListener("deviceready", onDeviceReady, false);
// Cordova est listo
function onDeviceReady() {
//...
}
// Callback del dilogo de aviso
function callbackAlertDismissed() {
//...
}
// Callback del dilogo de confirmacin
function callbackOnConfirm(buttonIndex) {
alert('Botn seleccionado ' + buttonIndex);
}
// Mostrar un dilogo de aviso
function showAlert() {
navigator.notification.alert(
'Eres el ganador!',
//
callbackAlertDismissed, //
'Fin de Juego',
//
'Continuar'
//
);
}

mensaje
callback
ttulo
texto botn

// Mostrar un dilogo de confirmacin


function showConfirm() {
navigator.notification.confirm(
'Qu deseas realizar?', // mensaje
callbackOnConfirm,
// callback
'Juego Pausado',
// ttulo
'Reiniciar,Continuar'
// texto de los botones
);
}
// Reproduce un sonido beep 3 veces
function playBeep() {
navigator.notification.beep(3);
}
// Realiza una vibracin durante 2 segundos
function vibrate() {
navigator.notification.vibrate(2000);
}
</script>
</head>
<body>

216

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

<p><a href="#" onclick="showAlert(); return false;">Mostrar


Alerta</a></p>
<p><a href="#" onclick="showConfirm(); return false;">Mostrar
Confirmacin</a></p>
<p><a href="#" onclick="playBeep(); return false;">Reproducir
Beep</a></p>
<p><a href="#" onclick="vibrate(); return false;">Vibracin</a></p>
</body>
</html>

Para
ms
informacin
consultar:
http://docs.phonegap.com/en/2.2.0/cordova_notification_notification.md.html
15.7.2. Informacin del dispositivo
A travs del objeto "device" podemos obtener informacin sobre el dispositivo, como el
modelo del dispositivo, la versin de PhoneGap utilizada, el nombre del sistema
operativo utilizado, el identificador nico del dispositivo (UUID), y la versin del sistema
operativo. En el cdigo siguiente se incluye un ejemplo de uso:
<!DOCTYPE html>
<html>
<head>
<title>Informacin del dispositivo</title>
<script type="text/javascript" charset="utf-8"
src="cordova-2.2.0.js"></script>
<script type="text/javascript" charset="utf-8">
// Wait for Cordova to load
document.addEventListener("deviceready", onDeviceReady, false);
// Cordova is ready
function onDeviceReady() {
var element = document.getElementById('deviceProperties');
element.innerHTML =
'Device Model: ' + device.name + '<br/>' +
'Device Cordova: ' + device.cordova + '<br/>' +
'Device Platform: ' + device.platform + '<br/>' +
'Device UUID: ' + device.uuid + '<br/>' +
'Device Version: ' + device.version + '<br/>';
}
</script>
</head>
<body>
<p id="deviceProperties">Loading device properties...</p>
</body>
</html>

15.7.3. Informacin de Conexin


El objeto "connection.type" devuelve una constante indicando el tipo de conexin que
est activa en el dispositivo. En el siguiente cdigo se muestra un ejemplo de uso, en el
que se obtiene el tipo de conexin y se muestra en un cuadro de dilogo. El array "states"
del ejemplo contiene todos los tipos de conexin soportados por "connection.type".
function checkConnection() {
var networkState = navigator.connection.type;

217

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

var states = {};


states[Connection.UNKNOWN]
states[Connection.ETHERNET]
states[Connection.WIFI]
states[Connection.CELL_2G]
states[Connection.CELL_3G]
states[Connection.CELL_4G]
states[Connection.NONE]

=
=
=
=
=
=
=

'Unknown connection';
'Ethernet connection';
'WiFi connection';
'Cell 2G connection';
'Cell 3G connection';
'Cell 4G connection';
'No network connection';

alert('Connection type: ' + states[networkState]);


}
checkConnection();

15.7.4. Aceleracin
Para obtener los valores del sensor de aceleracin del dispositivo en los ejes x, y, z,
podemos utilizar la funcin "accelerometer.getCurrentAcceleration". Esta funcin recibe
dos parmetros: el primero es la funcin callback que se llamar en caso de xito con los
valores obtenidos y el segundo el nombre de la funcin que se llamar en caso de error. A
continuacin se incluye un ejemplo de uso:
function onSuccess(acceleration) {
alert('Acceleration X: ' + acceleration.x + '\n' +
'Acceleration Y: ' + acceleration.y + '\n' +
'Acceleration Z: ' + acceleration.z + '\n' +
'Timestamp: '
+ acceleration.timestamp + '\n');
};
function onError() {
alert('onError!');
};
navigator.accelerometer.getCurrentAcceleration(onSuccess, onError);

Para
ms
informacin
puedes
consultar
la
direccin:
http://docs.phonegap.com/en/2.2.0/cordova_accelerometer_accelerometer.md.html.
15.7.5. Brjula
Para obtener la informacin del sensor de brjula del dispositivo utilizamos la funcin
"compass.getCurrentHeading", la cual devuelve un ngulo (entre 0 y 359.99) con la
direccin en la que est apuntando el dispositivo. Esta funcin recibe dos parmetros: la
funcin callback a la que se le pasarn los datos obtenidos y una funcin error que ser
llamada en caso de que no se pueda acceder al sensor. A continuacin se incluye un
ejemplo de uso:
function onSuccess(heading) {
alert('Heading: ' + heading.magneticHeading);
};
function onError(error) {
alert('CompassError: ' + error.code);
};

218

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

navigator.compass.getCurrentHeading(onSuccess, onError);

Para
ms
informacin
puedes
consultar
la
http://docs.phonegap.com/en/2.2.0/cordova_compass_compass.md.html.

direccin:

15.7.6. Geolocalizacin
Para acceder a la informacin del sensor GPS del dispositivo utilizamos la funcin
"geolocation.getCurrentPosition". Esta funcin recibe dos parmetros: el mtodo que se
llamar si se obtienen correctamente la informacin del GPS, y el mtodo que se llamar
en caso de error. A continuacin se incluye un ejemplo de uso:
function onSuccess(position) {
alert('Latitude: ' + position.coords.latitude + '\n' +
'Longitude: ' + position.coords.longitude + '\n' +
'Altitude: ' + position.coords.altitude + '\n' +
'Accuracy: ' + position.coords.accuracy + '\n' +
'Altitude Accuracy: ' + position.coords.altitudeAccuracy + '\n'
+
'Heading: ' + position.coords.heading + '\n' +
'Speed: ' + position.coords.speed + '\n' +
'Timestamp: ' + position.timestamp + '\n');
};
function onError(error) {
alert('code: '
+ error.code
+ '\n' +
'message: ' + error.message + '\n');
}
navigator.geolocation.getCurrentPosition(onSuccess, onError);

Para
ms
informacin
consultar:
http://docs.phonegap.com/en/2.2.0/cordova_geolocation_geolocation.md.html
15.7.7. Cmara
Podemos utilizar el mdulo de cmara para tomar imgenes mediante la llamada a la
funcin "camera.getPicture". Esta funcin recibe tres parmetros: la funcin callback que
se llamar si se obtiene la imagen correctamente, el segundo parmetro ser la funcin
callback de error, y el tercero las opciones de configuracin. En el ltimo parmetro
podemos indicar la calidad con la que se obtendr la imagen (en el rango [0,100]), el
origen del cual se obtendr la imagen (cmara del dispositivo [opcin por defecto],
librera de la cmara, o lbumes de fotos), y el destino o formato en el que se devolver la
imagen (como una cadena codificada en base64 o con la direccin de un fichero). A
continuacin se incluye un ejemplo de uso:
navigator.camera.getPicture(onSuccess, onFail,
{ quality: 50, destinationType: Camera.DestinationType.FILE_URI
});
function onSuccess(imageURI) {
var image = document.getElementById('myImage');
image.src = imageURI;
}

219

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

function onFail(message) {
alert('Failed because: ' + message);
}

En este ejemplo la imagen obtenida se muestra en una etiqueta <img> que se ha definido
en el html como vaca y con identificador myImage.
Para
ms
informacin
http://docs.phonegap.com/en/2.2.0/cordova_camera_camera.md.html

consultar:

15.7.8. API completa


Quedan muchas opciones que no hemos tratado en esta introduccin a PhoneGap, como:
Gestin de contactos: crear, obtener, modificar, guardar y borrar contactos.
Control de eventos:
pause, resume: cuando la aplicacin pierde o recibe el foco.
online, offline: cuando se obtiene o pierde la conexin a Internet.
Control de botones: atrs, men, bsqueda, llamada, fin de llamada.
Control de batera: estado, batera baja, batera crtica.
Botones de volumen.

Control del sistema de ficheros: lectura, escritura, navegacin.


Almacenamiento: acceso a las opciones de almacenamiento y control de base de datos
del dispositivo.
Captura de medios: audio, vdeo, imgenes.
Control multimedia: reproducir y grabar audio y vdeo.
Mostrar/ocultar una imagen como "splashscreen".

En la direccin http://docs.phonegap.com/en/2.2.0/index.html se puede consultar la API


completa de PhoneGap.

220

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

16. Ejercicios - PhoneGap


En primer lugar, y para todos los ejercicios, tenemos que descargar la ltima versin de
PhoneGap (www.phonegap.com) y descomprimirla.

16.1. Importar ejemplo PhoneGap (0.75 puntos)


En este ejercicio vamos a importar a Eclipse la aplicacin de ejemplo que viene junto con
el paquete de PhoneGap que hemos descargado. Para esto seguiremos los siguientes
pasos:
1. Importa en Eclipse el proyecto de ejemplo que est en la carpeta:
"lib/android/example". Para importarlo correctamente utiliza la opcin "Android
Project from Existing Code" de Eclipse.
2. Comprueba que en la carpeta "/assets/www/" est el fichero "cordova-VERSION.js",
y en "/libs/" est "cordova-VERSION.jar". Fjate como en la carpeta "/assets/www/"
est todo el contenido de la web: los ficheros HTML, las imgenes utilizadas, hojas de
estilo, javascript, etc.
3. Comprueba que en las propiedades del proyecto, en el "Java Build Path", en la
seccin "Libraries" est la librera "cordova-VERSION.jar". Si no est aadida aprieta
en "Add JARs" y adela desde el propio proyecto.
4. Comprueba que el fichero de cdigo Java tenga el "import" de la librera (import
org.apache.cordova.*;), que la clase herede de "DroidGap" en lugar de "Activity" y
que se llame a "super.loadUrl("file:///android_asset/www/index.html");" en el mtodo
"onCreate".
5. Abre el manifest de la aplicacin de ejemplo y revisa los permisos activados. Como
puedes ver estn puestos todos por defecto. Si no los vamos a utilizar todos, antes de
distribuir nuestra aplicacin, los tendremos que eliminar.
6. Corrige el proyecto para que compile con la versin 2.2 de Android (API 8). Para esto
debers modificar el "targetSdkVersion" en el manifest y tambin asegurarte de que
en las propiedades del proyecto (seccin Android) est correctamente indicada la
versin de la API.
7. Si intentamos ejecutar el proyecto as veremos que nos aparecen una serie de errores
en el manifest. Esto es debido a que se utilizan propiedades que son de una API
superior, elimnalas y ya podrs ejecutar el proyecto de ejemplo.

16.2. Hola Mundo con PhoneGap (0.75 puntos)


Siguiendo los pasos explicados en la seccin de teora "Configuracin desde Eclipse",
crea un proyecto en Eclipse y configralo para que funcione correctamente con
PhoneGap. Finalmente tendrs que obtener una aplicacin de Android que muestre
"Hola Mundo!".

221

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

16.3. Incorporando un proyecto de Sencha Touch (0.75 puntos)


En esta actividad vamos a incorporar a un proyecto PhoneGap el resultado obtenido del
ltimo ejercicio de la parte de programacin Web sobre Sencha Touch. Esta actividad
consista en realizar una aplicacin Web para mvil con un editor de notas. Asegrate de
haber completado ese ejercicio correctamente, de forma que se puedan aadir, editar y
modificar notas.
Crea un nuevo proyecto en Eclipse para PhoneGap y configralo (podemos aprovechar el
que hemos hecho en el ejercicio anterior Hola mundo, copiando y renombrando desde
Eclipse el proyecto). Copia en la carpeta "/assets/www/" el contido del ejercicio de
Sencha Touch.
Ejecuta el proyecto como "Android Application" y comprueba que todo funcione
correctamente.

16.4. Usando la API de PhoneGap (0.75 puntos)


En este ejercicio vamos a probar algunas de las funcionalidades que nos ofrece la API de
PhoneGap. Como estado de partida copia el proyecto realizado en el segundo ejercicio
(Hola Mundo) y renmbralo (esta accin la podemos realizar desde dentro de Eclipse).
Modifica el HTML del "Hola Mundo" para que cargue la librera de PhoneGap y espere
hasta que est lista (ver el cdigo bsico de ejemplo que se incluye en la seccin "API de
PhoneGap"). Cuando la API termine de cargarse muestra un aviso utilizando el sistema
de notificacin de PhoneGap.
Una vez cargada la librera muestra la informacin disponible del dispositivo y el estado
de la conexin. Esto lo podemos realizar sustituyendo el contenido de una etiqueta HTML
de la forma:
<html>
<head>
<script type="text/javascript" charset="utf-8">
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
var element = document.getElementById('idProperties');
element.innerHTML = 'NUEVO CONTENIDO';
}
</script>
</head>
<body>
<p id="idProperties">Cargando propiedades...</p>
</body>
</html>

Por ltimo aade un enlace en la parte superior que al pulsarlo muestre en una ventana de
alerta informacin sobre el sensor de aceleracin del dispositivo.

222

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

17. Bibliografa
17.1. Libros

Programming the Mobile Web (Maximiliano Firtman) - Ed: O'Reilly


http://oreilly.com/catalog/9780596807795
Programacin en Internet: Clientes Web (Sergio Lujn Mora) - Ed: Editorial Club
Universitario. Libro completo gratuito en pdf
http://rua.ua.es/dspace/bitstream/10045/16994/1/sergio_lujan-programacion_en_internet_clientes_we
HTML5 Mobile Web Development (Jake Carter) - Ed: O'Reilly
http://shop.oreilly.com/product/0636920014225.do
HTML5 and CSS3 Develop with Tomorrow's Standards Today (Brian P. Hogan) Ed: Pragmatic Bookshelf
http://shop.oreilly.com/product/9781934356685.do
jQuery Mobile: Up and Running (Maximiliano Firtman) - Ed: O'Reilly
http://oreilly.com/catalog/0636920014607
jQuery Mobile (Jon Reid) - Ed: O'Reilly
http://oreilly.com/catalog/0636920020585
Sencha Touch 1.0 Mobile JavaScript Framework (SSVV Narasimha Rao) - Ed: Packt
Publishing
http://www.packtpub.com/sencha-touch-1-0-mobile-javascript-framework/book

17.2. Enlaces

Gua Breve de Web Mvil de la W3C:


http://www.w3c.es/divulgacion/guiasbreves/webmovil
Estndar de HTML del W3C: http://www.w3.org/html/
Wikilibros - Lenguaje HTML: http://es.wikibooks.org/wiki/Lenguaje_HTML
Referencia detallada de estilos CSS: http://www.w3schools.com/cssref/default.asp
Especificaciones CSS: http://www.w3.org/Style/CSS/
Tutoriales CSS:
http://www.desarrolloweb.com/manuales/manual-css-hojas-de-estilo.html
Estndar HTML5 de la W3C: http://www.w3.org/TR/html5/
Demos de HTML5: http://html5demos.com/
Tutoriales y ejemplos de HTML5: http://www.html5rocks.com/en/
Introduccin a CSS3: http://www.w3schools.com/css3/default.asp
Tutoriales de CSS3 de la W3School:
http://www.w3.org/TR/2001/WD-css3-roadmap-20010523/
Pgina oficial de jQuery: http://jquery.com/
Pgina oficial de jQuery Mobile: http://jquerymobile.com
Galera de aplicaciones desarrolladas con jQuery Mobile: http://jqmgallery.com
Pgina oficial de Sencha Touch: http://www.sencha.com/

223

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

Programacin Web

Documentacin API Online de Sencha Touch: http://docs.sencha.com/touch/1-1/


Tutoriales de Sencha Touch: http://www.sencha.com/learn/touch/
Tutoriales de Sencha Touch en vdeo: http://vimeo.com/sencha
Pgina oficial de PhoneGap: http://phonegap.com/

17.3. Twitter

HTML5: http://twitter.com/html5
jQuery Mobile: http://twitter.com/jquerymobile
jQuery: http://twitter.com/jquery
jQuery Mobile Gallery: http://twitter.com/jqmgallery
Sencha Touch: http://twitter.com/senchatouch
PhoneGap: https://twitter.com/phonegap

17.4. Podcasts

Podcast oficial de jQuery: http://podcast.jquery.com/

224

Copyright 2012-13 Dept. Ciencia de la Computacin e IA All rights reserved.

También podría gustarte