{"id":3390,"date":"2025-03-18T14:47:23","date_gmt":"2025-03-18T17:47:23","guid":{"rendered":"https:\/\/thiagorossi.com.br\/blog\/?p=3390"},"modified":"2025-03-18T14:47:59","modified_gmt":"2025-03-18T17:47:59","slug":"formulario-jquery-com-validacao-realtime","status":"publish","type":"post","link":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/","title":{"rendered":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime"},"content":{"rendered":"<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">Tempo de leitura: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">minutos<\/span><\/span>\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime:<\/strong> Formul\u00e1rios de contato s\u00e3o elementos essenciais em sites modernos, permitindo que os visitantes entrem em contato com a empresa ou organiza\u00e7\u00e3o. A valida\u00e7\u00e3o em tempo real de formul\u00e1rios melhora a experi\u00eancia do usu\u00e1rio, fornecendo feedback imediato sobre a validade dos dados inseridos. <\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real utilizando jQuery, focando nas melhores pr\u00e1ticas e nas vers\u00f5es mais recentes da biblioteca.<\/p>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\"><strong>A Import\u00e2ncia da Valida\u00e7\u00e3o em Tempo Real e a Efici\u00eancia do jQuery<\/strong><\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">A valida\u00e7\u00e3o em tempo real de formul\u00e1rios evita que os usu\u00e1rios enviem dados inv\u00e1lidos, reduzindo a frustra\u00e7\u00e3o e melhorando a qualidade dos dados recebidos. jQuery simplifica a implementa\u00e7\u00e3o da valida\u00e7\u00e3o em tempo real, oferecendo m\u00e9todos e funcionalidades que facilitam a manipula\u00e7\u00e3o do DOM e a cria\u00e7\u00e3o de eventos interativos.<\/p>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\"><strong>Construindo um Formul\u00e1rio de Contato com Valida\u00e7\u00e3o em Tempo Real<\/strong><\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li class=\"has-medium-font-size\"><strong>Estrutura HTML:<\/strong>\n<ul class=\"wp-block-list\">\n<li>Crie um formul\u00e1rio com campos de entrada para nome, e-mail, assunto e mensagem.<\/li>\n\n\n\n<li>Adicione elementos de feedback para exibir mensagens de erro.<\/li>\n\n\n\n<li><strong>Exemplo:<\/strong>\n<ul class=\"wp-block-list\">\n<li><code>&lt;form id=\"formulario-contato\"><br>    &lt;label for=\"nome\">Nome:&lt;\/label><br>    &lt;input type=\"text\" id=\"nome\" name=\"nome\"><br>    &lt;span class=\"erro\" id=\"erro-nome\">&lt;\/span><br>    &lt;label for=\"email\">E-mail:&lt;\/label><br>    &lt;input type=\"email\" id=\"email\" name=\"email\"><br>    &lt;span class=\"erro\" id=\"erro-email\">&lt;\/span><br>    &lt;label for=\"assunto\">Assunto:&lt;\/label><br>    &lt;input type=\"text\" id=\"assunto\" name=\"assunto\"><br>    &lt;span class=\"erro\" id=\"erro-assunto\">&lt;\/span><br>    &lt;label for=\"mensagem\">Mensagem:&lt;\/label><br>    &lt;textarea id=\"mensagem\" name=\"mensagem\">&lt;\/textarea><br>    &lt;span class=\"erro\" id=\"erro-mensagem\">&lt;\/span><br>    &lt;button type=\"submit\">Enviar&lt;\/button><br>&lt;\/form><\/code><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Estiliza\u00e7\u00e3o CSS:<\/strong>\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\">Estilize o formul\u00e1rio e os elementos de feedback para criar uma interface amig\u00e1vel.<\/li>\n\n\n\n<li>Utilize cores e \u00edcones para indicar erros e sucesso.<\/li>\n\n\n\n<li><strong>Exemplo:<\/strong>\n<ul class=\"wp-block-list\">\n<li><code>.erro { <br>    color: red; <br>    font-size: 0.8em; <br>}<\/code><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>L\u00f3gica jQuery:<\/strong>\n<ul class=\"wp-block-list\">\n<li>Utilize jQuery para adicionar eventos de valida\u00e7\u00e3o aos campos de entrada.<\/li>\n\n\n\n<li>Valide os dados em tempo real, exibindo mensagens de erro quando necess\u00e1rio.<\/li>\n\n\n\n<li>Utilize express\u00f5es regulares para validar formatos de e-mail e outros dados.<\/li>\n\n\n\n<li><strong>Exemplo:<\/strong>\n<ul class=\"wp-block-list\">\n<li><code>$(document).ready(() => { <br>    $(\"#formulario-contato\").on(\"submit\", (event) => {<br>        event.preventDefault();<br>        validarFormulario(); <br>    }); <br><br>    function validarFormulario() { <br>        var nomeValido = validarNome(); <br>        var emailValido = validarEmail(); <br>        var assuntoValido = validarAssunto(); <br>        var mensagemValida = validarMensagem(); <br><br>        if (nomeValido &amp;&amp; emailValido &amp;&amp; assuntoValido &amp;&amp; mensagemValida) { <br>           alert(\"Formul\u00e1rio enviado com sucesso!\"); <br>       }  <br>    } <br><br>    function validarNome() { <br>        var nome = $(\"#nome\").val(); <br>        if (nome.trim() === \"\") { <br>            $(\"#erro-nome\").text(\"Nome \u00e9 obrigat\u00f3rio.\"); <br>            return false; <br>        } else { <br>            $(\"#erro-nome\").text(\"\"); <br>            return true; <br>        } <br>    } <br><br>    function validarEmail() { <br>        var email = $(\"#email\").val(); <br>        var regexEmail = \/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$\/; <br>        if (!regexEmail.test(email)) { <br>            $(\"#erro-email\").text(\"E-mail inv\u00e1lido.\");<br>            return false; <br>        } else {<br>            $(\"#erro-email\").text(\"\");<br>            return true; <br>        } <br>    } <br><br>    function validarAssunto() { <br>        var assunto = $(\"#assunto\").val(); <br>        if (assunto.trim() === \"\") { <br>            $(\"#erro-assunto\").text(\"Assunto \u00e9 obrigat\u00f3rio.\"); <br>            return false; <br>        } else { <br>            $(\"#erro-assunto\").text(\"\"); <br>            return true; <br>        } <br>    } <br><br>    function validarMensagem() { <br>        var mensagem = $(\"#mensagem\").val(); <br>        if (mensagem.trim() === \"\") { <br>            $(\"#erro-mensagem\").text(\"Mensagem \u00e9 obrigat\u00f3ria.\"); <br>            return false; <br>        } else { <br>            $(\"#erro-mensagem\").text(\"\"); <br>            return true; <br>        } <br>    } <br><br>    $(\"#nome, #email, #assunto, #mensagem\").on(\"input\", () => { <br>        validarFormulario(); <br>   }); <br>});<\/code><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li class=\"has-medium-font-size\"><strong>Acessibilidade:<\/strong>\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\">Adicione atributos ARIA para melhorar a acessibilidade do formul\u00e1rio.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">Utilize r\u00f3tulos claros e informativos para todos os campos.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">Forne\u00e7a mensagens de erro claras e concisas.<\/li>\n\n\n\n<li><strong>Exemplo:<\/strong>\n<ul class=\"wp-block-list\">\n<li><code>&lt;label for=\"nome\" aria-required=\"true\">Nome:&lt;\/label> <\/code><br><code>&lt;input type=\"text\" id=\"nome\" name=\"nome\" aria-describedby=\"erro-nome\"> <\/code><br><code>&lt;span class=\"erro\" id=\"erro-nome\" role=\"alert\">&lt;\/span><\/code><\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\"><strong>Melhores Pr\u00e1ticas e Otimiza\u00e7\u00e3o<\/strong><\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"has-medium-font-size\">Utilize express\u00f5es regulares para validar formatos de dados complexos.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">Utilize mensagens de erro claras e concisas.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">Forne\u00e7a feedback visual para indicar erros e sucesso.<\/li>\n\n\n\n<li class=\"has-medium-font-size\">Teste o formul\u00e1rio em diferentes navegadores e dispositivos.<\/li>\n<\/ul>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading has-large-font-size\"><strong>Conclus\u00e3o<\/strong><\/h2>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime<\/strong>: Formul\u00e1rios de contato com valida\u00e7\u00e3o em tempo real melhoram a experi\u00eancia do usu\u00e1rio e garantem a qualidade dos dados recebidos. Com jQuery, a cria\u00e7\u00e3o de formul\u00e1rios eficientes e acess\u00edveis se torna uma tarefa simples e eficiente. Ao seguir as melhores pr\u00e1ticas e utilizar as t\u00e9cnicas apresentadas neste artigo, voc\u00ea poder\u00e1 criar formul\u00e1rios de contato que atendem \u00e0s necessidades dos seus usu\u00e1rios e melhoram a comunica\u00e7\u00e3o com sua empresa ou organiza\u00e7\u00e3o.<\/p>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">Mas antes de dominar o jQuery, se for o seu caso, toda jornada tem um in\u00edcio. Vamos entender quais s\u00e3o os conhecimentos b\u00e1sicos necess\u00e1rios para aproveitar ao m\u00e1ximo esta poderosa biblioteca. Para iniciar seus estudos no jQuery, voc\u00ea precisar\u00e1 dominar as seguintes tecnologias:<\/p>\n\n\n\n<div class=\"wp-block-columns is-layout-flex wp-container-core-columns-is-layout-8f761849 wp-block-columns-is-layout-flex\">\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/html\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html.webp\" alt=\"HTML\" class=\"wp-image-600\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/html-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">HTML<\/figcaption><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/css\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux.webp\" alt=\"CSS\" class=\"wp-image-702\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/Capa-Artigos-Linux-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">CSS<\/figcaption><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"\/category\/javascript\"><img loading=\"lazy\" decoding=\"async\" width=\"758\" height=\"426\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript.webp\" alt=\"Javascript\" class=\"wp-image-804\" srcset=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript.webp 758w, https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/javascript-300x169.webp 300w\" sizes=\"auto, (max-width: 758px) 100vw, 758px\" \/><\/a><figcaption class=\"wp-element-caption\">JavaScript<\/figcaption><\/figure>\n<\/div>\n<\/div>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\">E se voc\u00ea gosta do nosso conte\u00fado, n\u00e3o deixe de contribuir adquirindo os servi\u00e7os e produtos dos nossos apoiadores e empresas que somos associados:<\/p>\n\n\n\n<div class=\"wp-block-columns is-layout-flex wp-container-core-columns-is-layout-8f761849 wp-block-columns-is-layout-flex\">\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/hostinger.com.br\/?REFERRALCODE=1THIAGO62\" target=\"_blank\" rel=\" noreferrer noopener\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/03\/hostinger.png\" alt=\"Hospedagem Hostinger\" class=\"wp-image-92\"\/><\/a><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/amzn.to\/3SNDYlc\" target=\"_blank\" rel=\" noreferrer noopener\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/ofertas-amazon.webp\" alt=\"Ofertas Amazon\" class=\"wp-image-1308\"\/><\/a><\/figure>\n<\/div>\n\n\n\n<div class=\"wp-block-column is-layout-flow wp-block-column-is-layout-flow\">\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/amzn.to\/3SNKmt0\" target=\"_blank\" rel=\" noreferrer noopener\"><img loading=\"lazy\" decoding=\"async\" width=\"300\" height=\"250\" src=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/08\/amazonprime.webp\" alt=\"Amazon Prime\" class=\"wp-image-1307\"\/><\/a><\/figure>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">Tempo de leitura: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">minutos<\/span><\/span>Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Formul\u00e1rios de contato s\u00e3o elementos essenciais em sites modernos, permitindo&#8230;<\/p>\n","protected":false},"author":1,"featured_media":3355,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[31],"tags":[],"class_list":["post-3390","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-jquery","wpcat-31-id"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.8 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime - BLOG THIAGO ROSSI<\/title>\n<meta name=\"description\" content=\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real...\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime - BLOG THIAGO ROSSI\" \/>\n<meta property=\"og:description\" content=\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real...\" \/>\n<meta property=\"og:url\" content=\"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/\" \/>\n<meta property=\"og:site_name\" content=\"BLOG THIAGO ROSSI\" \/>\n<meta property=\"article:published_time\" content=\"2025-03-18T17:47:23+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-03-18T17:47:59+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2025\/03\/Capa-Artigos.png\" \/>\n\t<meta property=\"og:image:width\" content=\"758\" \/>\n\t<meta property=\"og:image:height\" content=\"426\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Thiago Rossi\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Thiago Rossi\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/\"},\"author\":{\"name\":\"Thiago Rossi\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/person\\\/5f28286948ec2afdeb2e044a2196cd87\"},\"headline\":\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime\",\"datePublished\":\"2025-03-18T17:47:23+00:00\",\"dateModified\":\"2025-03-18T17:47:59+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/\"},\"wordCount\":516,\"publisher\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/03\\\/Capa-Artigos.png\",\"articleSection\":[\"jQuery\"],\"inLanguage\":\"pt-BR\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/\",\"name\":\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime - BLOG THIAGO ROSSI\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/03\\\/Capa-Artigos.png\",\"datePublished\":\"2025-03-18T17:47:23+00:00\",\"dateModified\":\"2025-03-18T17:47:59+00:00\",\"description\":\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real...\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#primaryimage\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/03\\\/Capa-Artigos.png\",\"contentUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2025\\\/03\\\/Capa-Artigos.png\",\"width\":758,\"height\":426,\"caption\":\"jQuery\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/formulario-jquery-com-validacao-realtime\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\",\"name\":\"THIAGO ROSSI\",\"description\":\"Mais de 20 anos de experi\u00eancia no mercado de TI!\",\"publisher\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\"},\"alternateName\":\"TR | CURSO WEB DEV\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#organization\",\"name\":\"THIAGO ROSSI\",\"alternateName\":\"TR | CURSO WEB DEV\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/04\\\/new-logo.webp\",\"contentUrl\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/wp-content\\\/uploads\\\/2024\\\/04\\\/new-logo.webp\",\"width\":300,\"height\":300,\"caption\":\"THIAGO ROSSI\"},\"image\":{\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"},\"sameAs\":[\"https:\\\/\\\/linkedin.com\\\/in\\\/thiagox86\"]},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/#\\\/schema\\\/person\\\/5f28286948ec2afdeb2e044a2196cd87\",\"name\":\"Thiago Rossi\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g\",\"caption\":\"Thiago Rossi\"},\"description\":\"Com mais de 20 anos de jornada na tecnologia, minha trajet\u00f3ria evoluiu do ensino t\u00e9cnico \u00e0 arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de solu\u00e7\u00f5es de Intelig\u00eancia Artificial nativa e an\u00e1lise de dados p\u00fablicos, utilizando o ecossistema PHP para transformar dados brutos em transpar\u00eancia e efici\u00eancia. Como autor e desenvolvedor, acredito na democratiza\u00e7\u00e3o do conhecimento. Essa vis\u00e3o resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura at\u00e9 os bastidores da ind\u00fastria de Jogos e IA. No universo de Game Design, sou autor do livro \\\"GDD \u2013 O Guia Definitivo\\\" e documento ativamente meus processos atrav\u00e9s de DevLogs, unindo rigor t\u00e9cnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso \u00e9 conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.\",\"sameAs\":[\"https:\\\/\\\/thiagorossi.com.br\\\/blog\",\"https:\\\/\\\/instagram.com\\\/thiagorossix86\",\"https:\\\/\\\/linkedin.com\\\/in\\\/thiagox86\"],\"url\":\"https:\\\/\\\/thiagorossi.com.br\\\/blog\\\/author\\\/thiagorossi\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime - BLOG THIAGO ROSSI","description":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real...","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/","og_locale":"pt_BR","og_type":"article","og_title":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime - BLOG THIAGO ROSSI","og_description":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real...","og_url":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/","og_site_name":"BLOG THIAGO ROSSI","article_published_time":"2025-03-18T17:47:23+00:00","article_modified_time":"2025-03-18T17:47:59+00:00","og_image":[{"width":758,"height":426,"url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2025\/03\/Capa-Artigos.png","type":"image\/png"}],"author":"Thiago Rossi","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"Thiago Rossi","Est. tempo de leitura":"4 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#article","isPartOf":{"@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/"},"author":{"name":"Thiago Rossi","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/person\/5f28286948ec2afdeb2e044a2196cd87"},"headline":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime","datePublished":"2025-03-18T17:47:23+00:00","dateModified":"2025-03-18T17:47:59+00:00","mainEntityOfPage":{"@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/"},"wordCount":516,"publisher":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#organization"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#primaryimage"},"thumbnailUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2025\/03\/Capa-Artigos.png","articleSection":["jQuery"],"inLanguage":"pt-BR"},{"@type":"WebPage","@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/","url":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/","name":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime - BLOG THIAGO ROSSI","isPartOf":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#primaryimage"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#primaryimage"},"thumbnailUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2025\/03\/Capa-Artigos.png","datePublished":"2025-03-18T17:47:23+00:00","dateModified":"2025-03-18T17:47:59+00:00","description":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime: Neste artigo, exploraremos como criar um formul\u00e1rio de contato com valida\u00e7\u00e3o em tempo real...","breadcrumb":{"@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/"]}]},{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#primaryimage","url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2025\/03\/Capa-Artigos.png","contentUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2025\/03\/Capa-Artigos.png","width":758,"height":426,"caption":"jQuery"},{"@type":"BreadcrumbList","@id":"https:\/\/thiagorossi.com.br\/blog\/formulario-jquery-com-validacao-realtime\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/thiagorossi.com.br\/blog\/"},{"@type":"ListItem","position":2,"name":"Formul\u00e1rio jQuery com Valida\u00e7\u00e3o Realtime"}]},{"@type":"WebSite","@id":"https:\/\/thiagorossi.com.br\/blog\/#website","url":"https:\/\/thiagorossi.com.br\/blog\/","name":"THIAGO ROSSI","description":"Mais de 20 anos de experi\u00eancia no mercado de TI!","publisher":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#organization"},"alternateName":"TR | CURSO WEB DEV","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/thiagorossi.com.br\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Organization","@id":"https:\/\/thiagorossi.com.br\/blog\/#organization","name":"THIAGO ROSSI","alternateName":"TR | CURSO WEB DEV","url":"https:\/\/thiagorossi.com.br\/blog\/","logo":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/new-logo.webp","contentUrl":"https:\/\/thiagorossi.com.br\/blog\/wp-content\/uploads\/2024\/04\/new-logo.webp","width":300,"height":300,"caption":"THIAGO ROSSI"},"image":{"@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/linkedin.com\/in\/thiagox86"]},{"@type":"Person","@id":"https:\/\/thiagorossi.com.br\/blog\/#\/schema\/person\/5f28286948ec2afdeb2e044a2196cd87","name":"Thiago Rossi","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/bb28b4665f4162bab9fbef8db5a7f00597f79ab90ece9a67189bb6bce78d5786?s=96&d=retro&r=g","caption":"Thiago Rossi"},"description":"Com mais de 20 anos de jornada na tecnologia, minha trajet\u00f3ria evoluiu do ensino t\u00e9cnico \u00e0 arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de solu\u00e7\u00f5es de Intelig\u00eancia Artificial nativa e an\u00e1lise de dados p\u00fablicos, utilizando o ecossistema PHP para transformar dados brutos em transpar\u00eancia e efici\u00eancia. Como autor e desenvolvedor, acredito na democratiza\u00e7\u00e3o do conhecimento. Essa vis\u00e3o resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura at\u00e9 os bastidores da ind\u00fastria de Jogos e IA. No universo de Game Design, sou autor do livro \"GDD \u2013 O Guia Definitivo\" e documento ativamente meus processos atrav\u00e9s de DevLogs, unindo rigor t\u00e9cnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso \u00e9 conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.","sameAs":["https:\/\/thiagorossi.com.br\/blog","https:\/\/instagram.com\/thiagorossix86","https:\/\/linkedin.com\/in\/thiagox86"],"url":"https:\/\/thiagorossi.com.br\/blog\/author\/thiagorossi\/"}]}},"_links":{"self":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/3390","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/comments?post=3390"}],"version-history":[{"count":4,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/3390\/revisions"}],"predecessor-version":[{"id":3394,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/posts\/3390\/revisions\/3394"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/media\/3355"}],"wp:attachment":[{"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/media?parent=3390"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/categories?post=3390"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/thiagorossi.com.br\/blog\/wp-json\/wp\/v2\/tags?post=3390"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}