Código de JavaScript - Validación automática de formularios

Requerimientos

Es obligatorio que los campos de los formularios tengan los atributos title y required.
Esta función se ejecuta utilizando el atributo onclick en el formulario.
Recibe como parámetro el objeto this.form

1.0
estrellaestrellaestrellaestrellaestrella(2)

Publicado el 27 de Abril del 2018gráfica de visualizaciones de la versión: 1.0
573 visualizaciones desde el 27 de Abril del 2018
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Validación de formulario</title>
</head>
<body>
	<form method="post">
		<label for="campo1">Campo 1</label>
		<br>
		<input type="text" id="campo1" name="campo1" required title="Campo 1">
		<br>
		<input type="button" onclick="validaForm(this.form);" value="Enviar">
	</form>
	<script>
		function validaForm(e){
		    var texts = e.getElementsByTagName('input');
		    for (var i = 0; i < texts.length; i++) {
		        if ((texts[i].type === 'text' || texts[i].type === 'password') && texts[i].value.trim() === "" && texts[i].required === true) {
		            var title = texts[i].getAttribute('title');
		            //alert(texts[i]);
		            alert("Por favor complete el campo: " + title);
		            texts[i].focus();
		            texts[i].style.borderColor = "red";
		            texts[i].style.borderStyle = "dashed";
		            return false;
		        }else if(texts[i].type === "text"){
		            texts[i].style.borderColor = "green";
		            texts[i].style.borderStyle = "outset";
		        }
		    }
		    var selects = e.getElementsByTagName('select');
		    for (var i = 0; i < selects.length; i++) {
		        if (selects[i].value === "" && selects[i].required === true) {
		            var title = selects[i].getAttribute('title');
		            alert("Por favor selecione: " + title);
		            selects[i].style.borderColor = "red";
		            selects[i].style.borderStyle = "dashed";
		            selects[i].focus();
		            return false;
		        }else{
		            selects[i].style.borderColor = "green";
		            selects[i].style.borderStyle = "outset";
		        }
		    }
		}
	</script>
</body>
</html>



Comentarios sobre la versión: 1.0 (2)

Imágen de perfil
28 de Abril del 2018
estrellaestrellaestrellaestrellaestrella
Muy útil para gestionar muchos input""
Responder
Imágen de perfil
29 de Abril del 2018
estrellaestrellaestrellaestrellaestrella
Buen aporte. Se agradece.
Responder

Comentar la versión: 1.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

2.0
estrellaestrellaestrellaestrellaestrella(1)

Publicado el 15 de Mayo del 2018gráfica de visualizaciones de la versión: 2.0
1.881 visualizaciones desde el 15 de Mayo del 2018
http://lwp-l.com/s4573