¡Esta es una revisión vieja del documento!


Parámetros

En este tema vamos a ver como incluir parámetros en las rutas. Antes de explicar en que consiste, volvamos a ver como funciona gmail.

Página “Recibidos” . URL=https://mail.google.com/mail/u/0/#inbox/147aa0e5820

Estamos en la página de recibidos pero estamos viendo un correo concreto. Para indicar que correo queremos ver se pone en la propia URL de la ruta. En el ejemplo de gmail vemos que se quiere ver el correo “147aa0e5820”.

El valor del correo a mostrar lo indicaremos como parámetro en la ruta ya que no es un valor fijo sino que queremos que nos pasen el valor del parámetro en variable para poder usar ese valor.

Definir el parámetro

Para poder definir un parámetro en la URL es tan sencillo como incluir el nombre de la variable en el path de la ruta precedido por ”:”. Veamos un ejemplo:

  $routeProvider.when('/pagina1/:variable1', {
    templateUrl: "pagina1.html",
    controller: "Pagina1Controller"
  });

  • Línea 1: Ahora en el path hemos añadido una variable llamada variable1.

Vamos ahora a poner ejemplos de posibles paths que casarían con la ruta que acabamos de definir y el valor de la variable variable1.

Path valor variable1
/pagina1/pepe pepe
/pagina1/34 34
/pagina1/hola_mundo hola_mundo
/pagina1/_ _
/pagina1/hola/ hola

Notar que si que se permite una barra al final pero no estará contenida como valor de la variable.

Pero NO podrá tener la siguientes formas:

  • /pagina1
  • /pagina1/
  • /pagina1/pepe/3
  • /pagina1/34/hola/mundo
  • /pagina1/hola_mundo/_

Es decir que si no tiene nada tras la segunda barra o tiene algo mas allá de la tercera barra el path no casará.

Mas de un parámetro

¿Que pasa si queremos 2 variable porque nos interesan 2 barras? Se pueden simplemente definir 2 variables, como en el siguiente ejemplo:

  $routeProvider.when('/pagina2/:variable1/:variable2', {
    templateUrl: "pagina2.html",
    controller: "Pagina2Controller"
  });

Vamos ahora a poner ejemplos de posibles paths que casarían con la ruta que acabamos de definir y el valor de las variables variable1 y variable2.

Path valor variable1 valor variable2
/pagina2/pepe/juan pepe juan
/pagina2/34/hola 34 hola
/pagina2/hola/1234 hola 1234
/pagina2/_/_ _ _
/pagina2/hola/adios/ hola adios

Tambien podemos definir partes estáticas entre las variable sin ningún problema como en:

  $routeProvider.when('/pagina3/rojo/:variable1/verde/:variable2/azul', {
    templateUrl: "pagina3.html",
    controller: "Pagina3Controller"
  });

Vamos ahora a poner ejemplos de posibles paths que casarían con la ruta que acabamos de definir y el valor de las variables variable1 y variable2.

Path valor variable1 valor variable2
/pagina3/rojo/pepe/verde/juan/azul pepe juan
/pagina3/rojo/34/verde/hola/azul 34 hola
/pagina3/rojo/hola/verde/1234/azul hola 1234
/pagina3/rojo/_/verde/_/azul _ _
/pagina3/rojo/hola/verde/adios/azul/ hola adios

Ruta indefinida

Hemos visto como podemos definir exactamente la forma de la ruta pero con parámetros, pero ¿que ocurre si no sabemos cuantas parte tiene la ruta? AngularJS nos permite añadir un “*” asterisco a la ruta y casara con cualquier tamaño.

  $routeProvider.when('/pagina4/:variable1*', {
    templateUrl: "pagina4.html",
    controller: "Pagina4Controller"
  });

Path
/pagina4/rojo rojo
/pagina4/rojo/34 rojo/34
/pagina4/hola/verde/1234/azul hola/verde/1234/azul
/pagina4/rojo/_/ rojo/_
/pagina4/rojo/hola/verde/adios/azul/ rojo/hola/verde/adios/azul

Como en el caso anterior también podríamos definir partes estáticas antes o después o varias variables.

Rutas optativas

Por último , ¿que pase si hay partes de la ruta que puede o no pueden estar? AngularJS nos permite añadir una incógnita al final de parámetro

  $routeProvider.when('/pagina5/:variable1*', {
    templateUrl: "pagina5.html",
    controller: "Pagina5Controller"
  });

Path valor variable1
/pagina5/pepe pepe
/pagina5/ undefined
/pagina5/hola_mundo hola_mundo

Si no está la parte optativa su valor será undefined.

Como en el caso anterior también podríamos definir partes estáticas antes o después o varias variables. Y por supuesto se pueden mezclar todo lo que hemos visto en la misma ruta.

Obtener el parámetro

Ahora que hemos definido el parámetro tenemos que poder obtener dicho valor. El valor se usa en el controlador ya que es el código JavaScript que está asociado a la página que acaba de cargarse gracias a la ruta.

La forma de obtener el valor es simplemente llamando al servicio $routeParams. Este servicio contiene tantas propiedades como parámetros hayamos definido en la ruta. Y el valor de cada propiedad del servicio es el valor de cada parámetro de la ruta.

Veamos un ejemplo.


Ejemplo

Como este ejemplo necesita de ver como cambia la URL del navegador , es mejor abrir en una nueva página el ejemplo.

Referencias

unidades/07_rutas/03_parametros.1409072647.txt.gz · Última modificación: 2014/08/26 19:04 por admin
Ir hasta arriba
CC Attribution-Share Alike 3.0 Unported
chimeric.de = chi`s home Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0