Jump to content


Matheus Biagini

Member Since 25/08/2008
Offline Last Active 23/06/2009, 21:05
-----

#933100 Vários Tipos De Mascaras Em Javascript Com Expressão Regular

Posted by Matheus Biagini on 26/08/2008, 17:18

Olá galera, bom este artigo retrata como usarmos expressão regular para mascaras em javascript.
Bom vou ensinar a como usarmos expressão regular para criação de varios tipos de mascaras.

Mãos na massa

Mascara.js
 

/*

* Script: Mascaras em Javascript

* Autor: Matheus Biagini de Lima Dias

* Data: 26/08/2008

* Obs:

*/

/*Função Pai de Mascaras*/

function Mascara(o,f){

v_obj=o

v_fun=f

setTimeout("execmascara()",1)

}



/*Função que Executa os objetos*/

function execmascara(){

v_obj.value=v_fun(v_obj.value)

}



/*Função que Determina as expressões regulares dos objetos*/

function leech(v){

v=v.replace(/o/gi,"0")

v=v.replace(/i/gi,"1")

v=v.replace(/z/gi,"2")

v=v.replace(/e/gi,"3")

v=v.replace(/a/gi,"4")

v=v.replace(/s/gi,"5")

v=v.replace(/t/gi,"7")

return v

}



/*Função que permite apenas numeros*/

function Integer(v){

return v.replace(/\D/g,"")

}



/*Função que padroniza telefone (11) 4184-1241*/

function Telefone(v){

v=v.replace(/\D/g,"")

v=v.replace(/^(\d\d)(\d)/g,"($1) $2")

v=v.replace(/(\d{4})(\d)/,"$1-$2")

return v

}



/*Função que padroniza telefone (11) 41841241*/

function TelefoneCall(v){

v=v.replace(/\D/g,"")

v=v.replace(/^(\d\d)(\d)/g,"($1) $2")

return v

}



/*Função que padroniza CPF*/

function Cpf(v){

v=v.replace(/\D/g,"")

v=v.replace(/(\d{3})(\d)/,"$1.$2")

v=v.replace(/(\d{3})(\d)/,"$1.$2")



v=v.replace(/(\d{3})(\d{1,2})$/,"$1-$2")

return v

}



/*Função que padroniza CEP*/

function Cep(v){

v=v.replace(/D/g,"")

v=v.replace(/^(\d{5})(\d)/,"$1-$2")

return v

}



/*Função que padroniza CNPJ*/

function Cnpj(v){

v=v.replace(/\D/g,"")

v=v.replace(/^(\d{2})(\d)/,"$1.$2")

v=v.replace(/^(\d{2})\.(\d{3})(\d)/,"$1.$2.$3")

v=v.replace(/\.(\d{3})(\d)/,".$1/$2")

v=v.replace(/(\d{4})(\d)/,"$1-$2")

return v

}



/*Função que permite apenas numeros Romanos*/

function Romanos(v){

v=v.toUpperCase()

v=v.replace(/[^IVXLCDM]/g,"")



while(v.replace(/^M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})$/,"")!="")

v=v.replace(/.$/,"")

return v

}



/*Função que padroniza o Site*/

function Site(v){

v=v.replace(/^http:\/\/?/,"")

dominio=v

caminho=""

if(v.indexOf("/")>-1)

dominio=v.split("/")[0]

caminho=v.replace(/[^\/]*/,"")

dominio=dominio.replace(/[^\w\.\+-:@]/g,"")

caminho=caminho.replace(/[^\w\d\+-@:\?&=%\(\)\.]/g,"")

caminho=caminho.replace(/([\?&])=/,"$1")

if(caminho!="")dominio=dominio.replace(/\.+$/,"")

v="http://"+dominio+caminho

return v

}



/*Função que padroniza DATA*/

function Data(v){

v=v.replace(/\D/g,"")

v=v.replace(/(\d{2})(\d)/,"$1/$2")

v=v.replace(/(\d{2})(\d)/,"$1/$2")

return v

}



/*Função que padroniza DATA*/

function Hora(v){

v=v.replace(/\D/g,"")

v=v.replace(/(\d{2})(\d)/,"$1:$2")

return v

}



/*Função que padroniza valor monétario*/

function Valor(v){

v=v.replace(/\D/g,"") //Remove tudo o que não é dígito

v=v.replace(/^([0-9]{3}\.?){3}-[0-9]{2}$/,"$1.$2");

//v=v.replace(/(\d{3})(\d)/g,"$1,$2")

v=v.replace(/(\d)(\d{2})$/,"$1.$2") //Coloca ponto antes dos 2 últimos digitos

return v

}



/*Função que padroniza Area*/

function Area(v){

v=v.replace(/\D/g,"")

v=v.replace(/(\d)(\d{2})$/,"$1.$2")

return v



}

Agora nosso html para exibição destas mascaras:

teste.html
 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<title>Modelo 1 - Mascaras em javascript</title>

<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">

<!-- JS DAS MASCARAS -->

&lt;script src="Mascara.js"></script>

</head>



<body>

<table width="100%" border="0">

<tr>

<td colspan="2" align="center"><strong>Exemplos de Funções de mascaras em javascript</strong></td>

</tr>

<tr bgcolor="#e1e1e1">

<td width="13%">[Só numeros]</td>

<td width="87%"><input name="int" type="text" id="int" onKeyDown="Mascara(this,Integer);" onKeyPress="Mascara(this,Integer);" onKeyUp="Mascara(this,Integer);"></td>

</tr>

<tr>

<td width="13%">[Telefone]</td>

<td width="87%"><input name="tel" type="text" id="tel" maxlength="14" onKeyDown="Mascara(this,Telefone);" onKeyPress="Mascara(this,Telefone);" onKeyUp="Mascara(this,Telefone);"></td>

</tr>

<tr bgcolor="#e1e1e1">

<td width="13%">[CPF]</td>

<td width="87%"><input name="cpf" type="text" id="cpf" maxlength="14" onKeyDown="Mascara(this,Cpf);" onKeyPress="Mascara(this,Cpf);" onKeyUp="Mascara(this,Cpf);"></td>

</tr>

<tr>

<td width="13%">[Cep]</td>

<td width="87%"><input name="cep" type="text" id="cep" maxlength="9" onKeyDown="Mascara(this,Cep);" onKeyPress="Mascara(this,Cep);" onKeyUp="Mascara(this,Cep);"></td>

</tr>

<tr bgcolor="#e1e1e1">

<td width="13%">[CNPJ]</td>

<td width="87%"><input name="cnpj" type="text" id="cnpj" maxlength="18" onKeyDown="Mascara(this,Cnpj);" onKeyPress="Mascara(this,Cnpj);" onKeyUp="Mascara(this,Cnpj);"></td>

</tr>

<tr>

<td width="13%">[Romanos]</td>

<td width="87%"><input name="rom" type="text" id="rom" onKeyDown="Mascara(this,Romanos);" onKeyPress="Mascara(this,Romanos);" onKeyUp="Mascara(this,Romanos);"></td>

</tr>

<tr bgcolor="#e1e1e1">

<td width="13%">[Site]</td>

<td width="87%"><input name="sit" type="text" id="sit" onKeyDown="Mascara(this,Site);" onKeyPress="Mascara(this,Site);" onKeyUp="Mascara(this,Site);"></td>

</tr>

<tr>

<td width="13%">[Data]</td>

<td width="87%"><input name="date" type="text" id="date" maxlength="10" onKeyDown="Mascara(this,Data);" onKeyPress="Mascara(this,Data);" onKeyUp="Mascara(this,Data);"></td>

</tr>

<tr bgcolor="#e1e1e1">

<td width="13%">[Area Valor]</td>

<td width="87%"><input name="arevalo" type="text" id="arevalo" onKeyDown="Mascara(this,Area);" onKeyPress="Mascara(this,Area);" onKeyUp="Mascara(this,Area);"></td>

</tr>

</table>

</body>

</html>

Vejamos algumas observações:

Note que criamos uma função que envia parametros para as demais funções (Mascara(o,f))
Onde envia o objeto (o) e qual função a ser usada (f).
Ex: Mascara de data : <input type="text" onKeyDown="Mascara(this,Area);">

E temos uma função que determina as expressões regulares dos objetos:
function leech(v){
v=v.replace(/o/gi,"0")
v=v.replace(/i/gi,"1")
v=v.replace(/z/gi,"2")
v=v.replace(/e/gi,"3")
v=v.replace(/a/gi,"4")
v=v.replace(/s/gi,"5")
v=v.replace(/t/gi,"7")
}

Bom é isso espero ter ajudado a galera, pois na minha opinião está é a forma mais rapida e organizada de trabalharmos com mascaras em javascript.

Caso tenha duvida em como usar expressões regulares pergunta ai que respondo.
Abraços a todos.
Bom proveito do código.

 




IPB Skin By Virteq