Como parte de HTML5 existe la posibilidad de agregar información a los inputs de un form, para realizar validaciones; podemos indicar si queremos que sea requerido, con el tipo de datos; number, email, etc restringimos los valores que pueden ser agregados, podemos usar alguna mascara para validaciones, colocar mensajes de error custom, etc (en la red existen muchos ejemplos acerca de como customizar formularios).
Ahora bien pongamos en contexto, tengo un formulario como este:
<form name="managerForm" id="managerForm">
<p>
Name:
<input id="managerNameText" required="required" placeholder="Write here the new manager name" size="40"/>
</p>
<p>
Email:
<input id="emailText" required="required" placeholder="myemail@myserver.com" type="email" />
</p>
<br/>
<a href="#" id="addManagerLink">Add a new Manager to the List</a>
</form>
Si presta atención al markup, podrá ver que se cuenta con dos inputs; un text normal y un email, el text es requerido al igual que el email, adicionalmente el email precisa que el texto introducido sea acorde a una dirección de correo.
Si hiciéramos submit al formulario con algún campo vacío veríamos como el browser se encarga de hacer las validaciones y mostrar los popups con los mensajes de errores.
Ahora bien, el tema es; que sucede si el requerimiento es que el formulario no se envié pero que los errores continúen funcionando de la misma forma. Para ello debemos usar las siguientes funciones en javascript:
var managerForm =
document.getElementById("managerForm");
if (managerForm.checkValidity()) {
// hacer algo
} else {
managerForm.reportValidity();
}
checkValidity retorna true si no existe ningún error en el formulario, de lo contrario retorna false.
reportValidity muestra los mensajes de error en los popups sobre los inputs correspondientes en caso que existan, similar a cuando hacemos submit.
Ahora bien pongamos en contexto, tengo un formulario como este:
<form name="managerForm" id="managerForm">
<p>
Name:
<input id="managerNameText" required="required" placeholder="Write here the new manager name" size="40"/>
</p>
<p>
Email:
<input id="emailText" required="required" placeholder="myemail@myserver.com" type="email" />
</p>
<br/>
<a href="#" id="addManagerLink">Add a new Manager to the List</a>
</form>
Si presta atención al markup, podrá ver que se cuenta con dos inputs; un text normal y un email, el text es requerido al igual que el email, adicionalmente el email precisa que el texto introducido sea acorde a una dirección de correo.
Si hiciéramos submit al formulario con algún campo vacío veríamos como el browser se encarga de hacer las validaciones y mostrar los popups con los mensajes de errores.
Ahora bien, el tema es; que sucede si el requerimiento es que el formulario no se envié pero que los errores continúen funcionando de la misma forma. Para ello debemos usar las siguientes funciones en javascript:
var managerForm =
document.getElementById("managerForm");
if (managerForm.checkValidity()) {
// hacer algo
} else {
managerForm.reportValidity();
}
checkValidity retorna true si no existe ningún error en el formulario, de lo contrario retorna false.
reportValidity muestra los mensajes de error en los popups sobre los inputs correspondientes en caso que existan, similar a cuando hacemos submit.
Comentarios