Formulario multi pasos con CSS y Jquery

Vamos a ver la forma de crear una sencillo formulario  del tipo multipaso, muy útil cuando tenemos formularios muy extensos o con demasiados campos, utilizaremos Jquery easing para animar la transición de las diferentes etapas o partes de las que se compondrá y le daremos el toque artístico con un poco de CSS (no esperen mucho, no soy bueno para el CSS).

Bueno lo primero sera confeccionar nuestro formulario, para ello utilizaré el siguiente código, el cual no presenta secretos.

En primer lugar definimos la cantidad de pasos para confeccionar una barra de progreso, para mantener informado al usuario y evitar que deje el formulario abandonado y perdamos trafico,  en este ejemplo serán 3 (Configurar tu cuenta, Perfil Social y Detalles Personales).

La barra de progreso sera una simple etiqueta ul  con un id llamado progreso, con sus correspondientes etiquetas li (tantas como pasos tenga el formulario) [highlight color=yellow]no olvidar asignar la clase active al primer li[/highlight] que mediante jQuery y CSS posteriormente la dotaremos de vida.

Luego de definir los step o pasos del formulario, creamos diferentes campos fieldsets para contener cada paso y dentro todo lo que se requiera (inputs, h2, h3, p, label, etc).

En cada fieldset, adicional a los campos que requiramos, debemos agregar un input tipo button para avanzar de paso en paso y otro para retroceder (según corresponda), por tanto en este ejemplo necesito agregar uno el primer fieldset para avanzar, dos al segundo y uno para retroceder en el ultimo junto a uno tipo submit.
Si probamos el código obtendremos una simple pagina de fondo blanco con un formulario donde veremos todos los campos así.

formulario_sin_estilo

Un toque de sensibilidad

Ahora lo principal es hacer mas vistoso nuestro formulario, para ello sacamos nuestros dotes artísticos (mas de alguien fumara algo para encontrar su inspiración xD) y nos zambullimos en CSS, yo no tengo estudios formales en CSS, pero la web es basta y repleta de información al respecto, al final de este articulo les dejare algunos link relacionados para el que desee profundizar alguno de los temas tratados en este post.

Primero importaremos una fuente tipografica desde el CDN de fuentes de google, yo usare la fuente Montcerrat, pero pueden usar la que estimen, desde google fonts podran navegar, buscar y elegir la que mas les agrade.

Un pequeño reset de estilos al documento,  sera muy básico.

Altura del documento html y aplicamos un combo de imagen como patern + gradient, cave señalar que la mayoría de CSS que usaremos, no aplica en internet explorer, esto debido a su incompatibilidad con esta versión de CSS 3 (pero bueno a quien le importa esos dinosaurio xD).

A pesar que mencione que no funcionaba bien en internet explorer  debemos asegurarnos que los otros navegadores entiendan nuestra codificación de estilos y para ello utilizaremos los prefijos para sus respectivos motores de render:

[checklist]
  • -webkit- : Para la familia Chrome / Chromium y Safari
  • -moz- : Para Mozilla Firefox y derivados
  • -o- : Para Opera (o si, aun existe)
  • -ms-: Para internet explorer 9 (pero linear-gradient no funciona bien en ie)
[/checklist] Aplicamos la fuente importada
Ahora el formulario y su contenido
Solo resta la parte superior del formulario, donde se marcan los pasos:
Con esto hemos terminado la parte “artistica” de nuestro formulario. Si probamos nuestro formulario notaran que se ve bien esteticamente, que solo vemos la primera parte del formulario, pero al darle click al boton Next, no pasa nada, ahora le daremos vida con un poco de JQuery.

Crearemo un nuevo archivo con extension js, llamenlo como quieran, yo lo llamare funciones.js

Ahora si hemos terminado, si desean que su formulario envié deben editar la ultima función del script.

Adicionalmente deben refererciar al plugin easing porque ocuparemos uno de sus metodos para animar nuestro formulario.

A continuacion les dejare un enlace con una demo de este formulario y un link donde podrán descargar el ejemplo completo listo para usar o editar a su conveniencia.

Referencias

[box type=mojo size=large]

w3schools.com: http://www.w3schools.com/css/css3_gradients.asp

Google Fonts: https://www.google.com/fonts

la imagen que use de gradient : http://www.colourlovers.com/

[/box]

Demo

Ver Demostración

Descargar ejemplo

[download id="609"]

5 comentarios en “Formulario multi pasos con CSS y Jquery”

  1. Esta excelente este post me sirvio muchisimo, solo falto agregar una alineacion de texto en el #progreso li y quedo perfecto


    #progreso li {
    list-style-type: none;
    color: #ffffff;
    text-transform: uppercase;
    font-size: 9px;
    text-align: center;
    width: 25%;
    float: left;
    position: relative;
    }

    Muchas gracias por tu tiempo.

    1. Hola Diego, lo más sencillo sería mediante ajax enviar los datos del formulario a un script php que reciba todos los campos del formulario, los valide y mediante la función mail de php los envíe por correo. Espero te aclare un poco tu duda, además debo decir que me han preguntado mucho esto, así que escribiré un post para explicar como hacerlo. Saludos cordiales.

  2. Hola claudio, Gracias por el aporte, una duda, supon que el form son puros select o radiobutton, como podria validar que no dejan alguna sin responder antes de casa siguiente paso??

     

    Gracias!

Agregar un comentario

Su dirección de correo no se hará público. Los campos requeridos están marcados *