Missing image

Validação com CSS para inputs HTML5 – valid / invalid – cm base64

Achei um código muito bacana que mostra um joinha verde caso seu input seja válido ou um jóia para baixo vermelho caso seja inválido, utilizando os novos :invalid e :valid. E de quebra utilizando base64 para que vocês não precisem requisitar as imgs.

Para você converter algum arquivo em base64 basta abrir seu terminal e digitar base64 minha_imagem.png. Caso não queira fazer via terminal existem inúmeros sites onde você passa a url da sua imagem e ele faz a conversão. Mas cuidado ao usar em MOBILE pois os mesmos possuem uma lentidão na conversão do base64.

[code language=”css”]
input:required:invalid, input:focus:invalid {
background-image: url(‘’);
background-position: right top;
background-repeat: no-repeat;
-moz-box-shadow: none;
}
input:required:valid {
background-image: url(‘’);
background-position: right top;
background-repeat: no-repeat;
}
[/code]

link do gist: https://gist.github.com/1951641

Para quem ainda não conhece o base64, ele é uma representação do seu arquivo em Base64(http://pt.wikipedia.org/wiki/Base64) para que o mesmo não precise fazer a requisição da imagem, mas deve ser usado com cautela, pois o mesmo vai “aumentar” o tamanho da sua imagem em 33%. Entretanto se suas imagens estão vindo normalmente e seu navegador não carregou, irá aparecer um quadrado sem a imagem. O que não acontece com o base64 pois as imagens são criadas na hora da leitura do css.

Além do base64 também utilizamos as pseudo-classes: required, valid e invalid; que vieram com o HTML5.

Um exemplo interessante de validação é utilizar expressões regulares para aceitar apenas certos valores, como no exemplo abaixo:

[code language=”html”]
<input type="text" id="cep" name="cep" pattern="\d{8}" placeholder="Entre com os numeros do seu CEP" required />
[/code]

Mas com alguns tipos novos de input do HTML5 existem alguns que não precisam de regex para conferir se o valor está correto, por exemplo: number, email, url.

[code language=”html”]
<input type="email" id="email" name="email" placeholder="Digite um email valido" required />
<input type="number" id="idade" name="idade" required />
<input type="url" id="site" name="site" required />
[/code]

Caso possuam dúvidas deixem nos comentários.

Exemplos: http://jsfiddle.net/suissa/q6jX8/