Hace algún largo tiempo ya, les trajimos un tutorial sobre como armar un formulario de contacto para nuestros sitios Web, en el cual vimos todo el proceso de creación, desde el armado hasta el envío de los datos vía correo electrónico.
Pero como el tiempo pasa, y nos vamos poniendo viejos, y sabemos que las soluciones no son eternas ni apropiadas para estos tiempos, hoy hemos decidido sacar a relucir nuestros talentos musicales y poéticos desarrollísticos (¿desarrolladores?) y traerles una nueva versión de este formulario, ahora con sabor a limón y algunas características que lo convierten en una versión mucho más óptima que la anterior.
El detalle, como siempre, después del salto.
Como siempre, lo primero:
Detalles del tutorial
- Tiempo aproximado de implementación: 30 minutos.
- Dificultad: Básico (para implementar tal cual) – Intermedio (para personalizar).
- Conocimientos previos requeridos: Entendimiento de HTML, CSS, jQuery y PHP.
Implementos necesarios:
- Un editor Web (Recomendamos Aptana Studio o Notepad++, ambos gratuitos).
Ahora, la pregunta de rigor. ¿Qué trae de nuevo este formulario 2.0?:
Así que con eso claro, vamos, manos a la obra:
Separaremos este desarrollo en las siguientes partes:
El armado del formulario es bastante estándar:
<div id="container"> <form name="formulario" id="formulario" method="post" action="envio.php"> <fieldset><h2>Contacto</h2></fieldset> <div> <label for="nombre">Nombre: </label> <input type="text" name="nombre" id="nombre" size="60"> <span id="validar-nombre"></span> </div> <div> <label for="correo">Correo:</label> <input type="text" name="correo" id="correo" size="60"/> <span id="validar-correo"></span> </div> <div><label for="sitio">Sitio Web:</label> <input type="text" name="sitio" id="sitio" size="60"/> <span id="validar-sitio"></span> </div> <div> <label for="mensaje">Mensaje: </label> <textarea name="mensaje" id="mensaje" rows="10" cols="56"></textarea> <span id="validar-mensaje"></span> </div> <p id="envio"> <input type="submit" name="enviar" id="enviar" value="Enviar" /> </p> </form> </div>
Con este código tendremos un formulario bastante estándar armado en nuestra página de contacto. Este contará con campos de texto para que el visitante ingrese su nombre, correo electrónico y sitio Web, así como un área de texto para que ingrese su mensaje. Y obviamente al final añadimos un botón para el envío.
Como podrán fijarse, a continuación de cada campo de texto y área de texto, hemos añadido un span sin contenido. Esto lo hemos hecho para insertar mensajes y resultados de las validaciones posteriormente mediante jQuery.
A continuación, haremos la estilización del formulario, mediante CSS.
body { height: 100%; background: #348075; font-family: Arial; font-size: 11px; color: white; } #container { width: 1000px; margin: 0 auto; background: #5b5c5c; border: 1px solid white; -moz-border-radius: 20px; -webkit-border-radius: 20px; } #formulario { padding: 1em; } #formulario fieldset { width: 400px; padding: 0 0 0 0; border: 0; } #formulario label { display: block; padding: 5px 0 5px 0; } #formulario input[type=text], textarea { padding: 10px 0 10px 0; border: 1.5px solid black; color: #5b5c5c; font-family: inherit; font-size: inherit; -moz-border-radius: 5px; -webkit-border-radius: 3px; } #formulario input[type=text]:focus, textarea:focus { background: #f5f2c9; } #formulario input[type=submit] { border: none; margin-right: 1em; padding: 6px; text-decoration: none; font-size: 12px; font-weight: bold; -moz-border-radius: 4px; background: #348075; color: white; width: 100px; } #formulario input[type=submit]:hover { background: #287368; cursor: pointer; } #validar-nombre, #validar-correo, #validar-sitio, #validar-mensaje { position: absolute; width: 100px; } #validar-nombre img, #validar-correo img, #validar-mensaje img { padding:10px 0 0 5px; }
Como podrán ver, en algunas partes hemos utilizado la propiedad border-radius (con moz y webkit para apuntar a distintos navegadores). Esta propiedad, tal como hemos indicado anteriormente, es de CSS3, por lo que no está completamente soportada por todos los navegadores, especialmente los más antiguos. El efecto que logra es el de bordes redondeados, así que ojo, si utilizan IE o algún navegador de mayor antiguedad no lo podrán apreciar.
Acá debemos fijarnos en algunas cosas. Primero, debemos asegurarnos de descargar e incluir jQuery en la cabecera de nuestro formulario, y luego, crear un documento js en el que incluiremos el código en jQuery que hará las validaciones y el correspondiente a Javascript que contendrá la expresión regular que evaluará la dirección de correo ingresada para ver si es válida. Partamos con jQuery:
$(function(){ var valor; var i = 0; $('#nombre').focus(function(){ $('#resultado-nombre').remove(); $('#validar-nombre').append('<p>* Obligatorio</p>'); }); $('#nombre').blur(function(){ $('.advertencia').remove(); valor = $('#nombre').val(); if(valor != '') { $('<img src="imagenes/accept.png" id="resultado-nombre" />').appendTo('#validar-nombre'); } else { $('<img src="imagenes/delete.png" id="resultado-nombre" />').appendTo('#validar-nombre'); } }); $('#correo').focus(function(){ $('#resultado-correo').remove(); $('#validar-correo').append('<p>* Obligatorio</p>'); }); $('#correo').blur(function(){ $('.advertencia').remove(); valor = $('#correo').val(); if(valor != '') { if(validaCorreo(valor)){ $('<img src="imagenes/accept.png" id="resultado-correo" />').appendTo('#validar-correo'); var valido = true; } else { $('<span id="resultado-correo">Correo no valido</span>').appendTo("#validar-correo"); } } else { $('<img src="imagenes/delete.png" id="resultado-correo" />').appendTo('#validar-correo'); } }); $('#sitio').focus(function(){ $('#validar-sitio').append('<p>* Opcional</p>'); }); $('#sitio').blur(function(){ $('.advertencia').remove(); }); $('#mensaje').focus(function(){ $('#resultado-mensaje').remove(); $('#validar-mensaje').append('<p>* Obligatorio</p>'); }); $('#mensaje').blur(function(){ $('.advertencia').remove(); valor = $('#mensaje').val(); if(valor != '') { $('<img src="imagenes/accept.png" id="resultado-mensaje" />').appendTo('#validar-mensaje'); } else { $('<img src="imagenes/delete.png" id="resultado-mensaje" />').appendTo('#validar-mensaje'); } }); $('#enviar').click(function(){ if($('#nombre').val()!= '' && $('#correo').val()!='' && $('#mensaje').val()!='' && valido) { $('.advertencia').remove(); $('#envio').append('<img src="imagenes/ajax-loader.gif" alt="Procesando envio" id="cargando" />'); var nombre = $('#nombre').val(); var correo = $('#correo').val(); var sitio = $('#sitio').val(); var mensaje = $('#mensaje').val(); $.ajax({ url: 'envio.php', type: 'POST', data: 'nombre=' + nombre + '&correo=' + correo + '&sitio=' + sitio + '&mensaje=' + mensaje, success: function(resultado) { $('#respuesta').remove(); $('#envio').append('<span id="respuesta">' + resultado + '</span>'); $('#cargando').fadeOut(500, function() { $(this).remove(); }); } }); return false; } else { $('#envio').append('<span>Debe completar los datos requeridos.</span>'); return false; } }); });
Varias cosas a las que ponerle atención en el código anterior:
El código básicamente ejecuta acciones cada vez que se selecciona un campo de texto (focus) y/o se sale de el (blur). Ahí evalua de acuerdo a los parámetros que hemos definido (que existan datos) y en base a eso muestra un resultado de la validación. Luego, al final, cuando se hace click en el botón de envío, evalúa que existan datos en todos los campos y en ese caso envía. De lo contrario, despliega un mensaje indicando la necesidad de completar el formulario.
Luego, a continuación del código jQuery, incluiremos una función en Javascript que evaluará el correo mediante una expresión regular para verificar que tenga el formato correcto:
function validaCorreo(correo) { var expresion = new RegExp(/^(("[\w-\s]+")|([\w-]+(?:\.[\w-]+)*) |("[\w-\s]+")([\w-]+(?:\.[\w-]+)*))(@((?:[\w-]+\.)*\w[\w-]{0,66}) \.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][0-9]\. |1[0-9]{2}\.|[0-9]{1,2}\.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\.) {2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\]?$)/i); return expresion.test(correo); }
Entre estos 2 códigos se encargan de toda la validación del formulario, tal como indicamos, en tiempo real. Lo que nos queda hacer ahora es crear nuestro script en PHP para el envío final de los datos.
<?php /* Recepcionamos los datos enviados asincrónicamente */ $nombre = $_POST['nombre']; $correo = $_POST['correo']; $sitio = $_POST['sitio']; $mensaje = $_POST['mensaje']; /* Definimos el correo donde enviaremos el mensaje y el asunto */ $destino = "correo@ejemplo.com"; $asunto = "Contacto sitio Web"; /* Definimos el formato del mensaje a enviar */ $cuerpo = "<strong>Nombre: </strong>".$nombre."<br /> <strong>Correo: </strong>".$correo."<br /> <strong>Sitio Web: </strong>".$sitio."<br /> <strong>Mensaje: </strong>".$mensaje; /* Definimos las cabeceras del mensaje */ $cabecera = "MIME-Version: 1.0\r\n"; $cabecera .= "Content-type:text/html; charset=iso-8859-1\r\n"; $cabecera .= "From: $correo\r\n"; $cabecera .= "Reply-to: $correo\r\n"; $cabecera .= "Cc: $correo\r\n"; /* Enviamos vía correo, devolviendo un mensaje en caso de éxito o falla */ if(mail($destino, $asunto, $cuerpo, $cabecera)) { echo 'Su mensaje ha sido enviado. De ser necesario, nos pondremos en contacto con Ud.'; } else { echo 'No se pudo enviar el mensaje. Inténtelo nuevamente'; } ?>
Los mensajes desplegados en el if y else cuando enviamos el correo son aquellos que son devueltos al método .ajax de jQuery (el parámetro resultado del que hablamos anteriormente), los cuales son desplegados en el formulario.
Y con eso tenemos nuestro formulario de contacto terminado, el cual valida en tiempo real y envía los datos de forma asincrónica. En caso de que el visitante tenga Javascript desactivado en su navegador, esto se ejecutará de forma normal, es decir, el script PHP se cargará al momento de presionar el botón Enviar y no habrá validación en tiempo real.
Antes de terminar:
Y como siempre, les recordamos que este tutorial ha sido:
Cualquier duda o comentario que puedan tener, los invitamos a dejarnos unas líneas en el área habilitada a continuación.
Esperamos que este tutorial haya sido de utilidad para Uds.
Muchas gracias por leer y será hasta una próxima oportunidad.
5:35:20 pm
gracias!
1:34:09 am
Hola, excelente tutorial!
Creo que encontré una pequeño problema, pues el mensaje “Debe completar los datos requeridos.” se repite cada vez que presionas enviar…
🙂
11:20:14 pm
Hola! muy bueno! ah me sirvio de mucho! bueno soy nuevo en PHP y MySQL y quisiera pedirte un gran favor si pudieras modificar el codigo para poder enviar los datos a una tabla en una base de datos, me refiero a que a parte que envie los datos a mi email que tambien los guarde en una base de datos.
nota: no te preocupes por hacer la base de datos y todos eso lo unico que quiero saber es como seria el codigo modificado con lo que te estoy pidiendo
si puedes me lo envias a mi email 🙂
muchas gracias!
Excelente Pagina!!
1:44:38 pm
Hola. Muy bueno!!!!! Baje el código pero no veo las correcciones actualizadas. Soy nuevo en esto y estoy tratando de configurar mi formulario, si no es molestia podría pedirles que me envíen el archivo corregido. Desde ya muchas gracias.
6:32:43 am
Hola.. Gracias por vuestro trabajo..
Hace unos dias me baje el formulario y funciono perfectamente..
lo he estado modificando en el Css. Me lo he vuelto a Bajar y ahora no me funciona..
lo bajo..descomprimo.. abro contacto y cuando envio me sale esto..:: Nombre: “.$nombre.”
Correo: “.$correo.”
Sitio Web: “.$sitio.”
Mensaje: “.$mensaje; /* Definimos las cabeceras del mensaje */ $cabecera = “MIME-Version: 1.0\r\n”; $cabecera .= “Content-type:text/html; charset=iso-8859-1\r\n”; $cabecera .= “From: $correo\r\n”; $cabecera .= “Reply-to: $correo\r\n”; $cabecera .= “Cc: $correo\r\n”; /* Enviamos v�a correo, devolviendo un mensaje en caso de �xito o falla */ if(mail($destino, $asunto, $cuerpo, $cabecera)) { echo ‘Su mensaje ha sido enviado. De ser necesario, nos pondremos en contacto con Ud.’; } else { echo ‘No se pudo enviar el mensaje. Inténtelo nuevamente’; } ?>
Me sale esto abajo…
MUCHAS GRACIAS…
1:37:30 am
excelente explicacion, me ha servido muchisimo, gracias a esta gran pagina.
10:52:25 am
Hola necesito ayuda, me baje los archivos y cuando lo pruebo me sale el siguiente error:
Nombre: “.$nombre.”
Correo: “.$correo.”
Sitio Web: “.$sitio.”
Mensaje: “.$mensaje; /* Definimos las cabeceras del mensaje */ $cabecera = “MIME-Version: 1.0\r\n”; $cabecera .= “Content-type:text/html; charset=iso-8859-1\r\n”; $cabecera .= “From: $correo\r\n”; $cabecera .= “Reply-to: $correo\r\n”; $cabecera .= “Cc: $correo\r\n”; /* Enviamos v�a correo, devolviendo un mensaje en caso de �xito o falla */ if(mail($destino, $asunto, $cuerpo, $cabecera)) { echo ‘Su mensaje ha sido enviado. De ser necesario, nos pondremos en contacto con Ud.’; } else { echo ‘No se pudo enviar el mensaje. Inténtelo nuevamente’; } ?>
Eso pasa cuando lo descargo y despues de haber abierto el archivo envio.php con worpad, ahora cuando lo hago desde aqui en demostracion todo sale ok.
Atentamente
Jose Zevallos
9:32:24 pm
hola, muchas gracias por este tutorial me baje los codigos pero los abri todos con el WordPad pero tube un solo problema, en la parte del codigo que me dice
$destino = “correo@ejemplo.com”;
pongo mi correo y cuando lleno los campos en mi formulario y presiono enviar me sale el icono cargado al lado pero luego reviso mi correo y no me aparece ningun correo recibido. ¿Debo escribir mi correo en alguna otra parte del codigo? o que debo hacer para que funcione
PD: mi pagina no esta publicada en internet es solo para una prueba
de ante mano muchas gracias y excelente pagina
2:17:27 pm
Hola, muchas gracias por compartir con nosotros toda esta información tan valiosa.
Desgracidamente me ocurre lo mismo que a Jose Cevallos y a Rodrigo.
¿Cómo podemos solucionarlo?
Gracias de nuevo!!!!
3:09:18 pm
Hola, lo he subido al servidor y ya no me aparece esa ristra del php, todo va guay, pero cuando le doy a enviar apacere el icono de “en proceso” y así hasta la eternidad. No se envia. No se que he podido hacer mal, no he modificado el CSS, sólo he subido al servidor lo que me he descargado de esta web, lo he linkado a mi sitio y he cambiado la dirección de correo en el php.
Debo ser muy torpe.
Gracias anyway