Validar formularios accesibles sin onsubmit
Hace unos meses publiqué un artículo denominado formularios accesibles con javascript, para ello usaba el atributo onsubmit de la etiqueta form para validar el formulario web con javascript.
A continuación, explicaré con un ejemplo como implementar en nuestro desarrollo web, javascript no intrusivo para validar formularios accesibles sin onsubmit.
Ventajas validar formularios accesibles sin onsubmit
- Se cumplen los estándares web del W3C.
- Se cumplen las pautas de accesibilidad web.
- Código HTML más limpio y compacto.
- No es necesario tener javascript habilitado.
- Compatible con la totalidad de navegadores web.
Ejemplo validar formularios accesibles sin onsubmit
Descarga el ejemplo validar formularios accesibles sin onsubmit.
Para validar formularios web lo primero que debemos hacer es embeber el código javascript o cargarlo mediante un fichero externo entre las etiquetas head de nuestro código html:
<script type="text/javascript"> /** * Validar Formulario Accesible sin onSubmit * (c) 2009 Alejandro Arco * Por Alejandro Arco - https://alejandroarco.es */ validateForm=function() { var nombre = new Array(document.getElementById('nombre'), document.frm['nombre'].value); var apellidos = new Array(document.getElementById('apellidos'), document.frm['apellidos'].value); var email = new Array(document.getElementById('email'), document.frm['email'].value); var telefono = new Array(document.getElementById('telefono'), document.frm['telefono'].value); var consulta = new Array(document.getElementById('consulta'), document.frm['consulta'].value); var submit = document.getElementById('submit'); /* Eventos */ nombre[0].onfocus = onFocus; nombre[0].onblur = onBlur; apellidos[0].onfocus = onFocus; apellidos[0].onblur = onBlur; email[0].onfocus = onFocus; email[0].onblur = onBlur; telefono[0].onfocus = onFocus; telefono[0].onblur = onBlur; consulta[0].onfocus = onFocus; consulta[0].onblur = onBlur; submit.onclick = validateFields; /* Funciones */ function onFocus() { if(document.frm[this.name].value==eval(this.name)[1]) document.frm[this.name].value='' } function onBlur() { var value = document.frm[this.name].value; value = value.replace(/^\s*/, ''); value = value.replace(/\s*$/, ''); if(!value) document.frm[this.name].value = eval(this.name)[1] } function validateFields() { if(document.frm['nombre'].value == nombre[1]) { document.frm['nombre'].focus(); alert('El campo "nombre" es obligatorio.'); } else if(document.frm['apellidos'].value == apellidos[1]) { document.frm['apellidos'].focus(); alert('El campo "apellidos" es obligatorio.'); } else if(document.frm['email'].value == email[1]) { document.frm['email'].focus(); alert('El campo "email" es obligatorio.'); } else if(document.frm['consulta'].value == consulta[1]) { document.frm['consulta'].focus(); alert('El campo "consulta" es obligatorio.'); } else { return true; } return false; } } if(document.all&&window.attachEvent) { window.attachEvent("onload",validateForm); } // IE-Win else if(window.addEventListener) { window.addEventListener("load",validateForm,false); } // Otros </script>
Posteriormente, crearemos nuestro formulario web accesible y añadiremos su código entre las etiquetas body de nuestro contenido HTML.
<form name="frm" action="#submit" enctype="multipart/form-data" method="post"> <fieldset> <legend>Formulario accesible</legend> <p>Ejemplo de <strong>formulario accesible</strong> con <em>javascript</em> sin uso del atributo <em>onsubmit</em>, no olvide que todos los campos marcados con (*) son obligatorios.</p> <label for="nombre">Nombre *</label><input name="nombre" id="nombre" accesskey="n" tabindex="1" value="- nombre -" type="text" /> <label for="apellidos">Apellidos *</label><input name="apellidos" id="apellidos" accesskey="a" tabindex="2" value="- apellidos -" type="text" /> <label for="email">Email *</label><input name="email" id="email" accesskey="e" tabindex="3" value="- email -" type="text" /> <label for="telefono">Teléfono</label> <input name="telefono" id="telefono" accesskey="t" tabindex="4" value="- teléfono -" type="text" /> <label for="consulta">Consulta *</label><textarea name="consulta" id="consulta" accesskey="c" tabindex="5" cols="1" rows="1">- consulta -</textarea> <label for="submit"><input name="submit" id="submit" accesskey="s" tabindex="6" value="Enviar" type="submit" /></label> </fieldset> </form>
En este ejemplo no hacemos uso del atributo onsubmit para validar nuestro formulario web mediante javascript no intrusivo, de este modo, obtenemos un código html más limpio y compacto.
Si tenéis alguna duda referente a la validación de formularios web accesibles sin onsubmit, dejadme un comentario en este artículo y lo responderé gustosamente. ¿Habéis validado anteriormente formularios web con javascript no intrusivo?
Hola, muy buen aporte. Soy un tanto novato en php, y ni eso en javascript, mi pregunta es si desde el javascript puedo llamar a mi función en php para crear las Session.
gracias, ALe
Hola y gracias por tu aporte, tengo una duda con este código para omitir la validación con onsubmit: