JAVASCRIPT – Máscara de Moeda

Com esta função é possível criar uma máscara de preenchimento de data no Navegador.
No exemplo, foi utilizado os separadores utilizados no Brasil para formatar em reais (R$) porém é possível configurar para trabalhar com outra moeda facilmente.
Código:

<script language=”javascript”>
//—————————————————–
//Funcao: MascaraMoeda
//Sinopse: Mascara de preenchimento de moeda
//Parametro:
// objTextBox : Objeto (TextBox)
// SeparadorMilesimo : Caracter separador de milésimos
// SeparadorDecimal : Caracter separador de decimais
// e : Evento
//Retorno: Booleano
//Autor: Gabriel Fróes – www.codigofonte.com.br
//—————————————————–
function MascaraMoeda(objTextBox, SeparadorMilesimo, SeparadorDecimal, e){
var sep = 0;
var key = ”;
var i = j = 0;
var len = len2 = 0;
var strCheck = ‘0123456789’;
var aux = aux2 = ”;
var whichCode = (window.Event) ? e.which : e.keyCode;
if (whichCode == 13) return true;
key = String.fromCharCode(whichCode); // Valor para o código da Chave
if (strCheck.indexOf(key) == -1) return false; // Chave inválida
len = objTextBox.value.length;
for(i = 0; i < len; i++)
if ((objTextBox.value.charAt(i) != ‘0’) && (objTextBox.value.charAt(i) != SeparadorDecimal)) break;
aux = ”;
for(; i < len; i++)
if (strCheck.indexOf(objTextBox.value.charAt(i))!=-1) aux += objTextBox.value.charAt(i);
aux += key;
len = aux.length;
if (len == 0) objTextBox.value = ”;
if (len == 1) objTextBox.value = ‘0’+ SeparadorDecimal + ‘0’ + aux;
if (len == 2) objTextBox.value = ‘0’+ SeparadorDecimal + aux;
if (len > 2) {
aux2 = ”;
for (j = 0, i = len – 3; i >= 0; i–) {
if (j == 3) {
aux2 += SeparadorMilesimo;
j = 0;
}
aux2 += aux.charAt(i);
j++;
}
objTextBox.value = ”;
len2 = aux2.length;
for (i = len2 – 1; i >= 0; i–)
objTextBox.value += aux2.charAt(i);
objTextBox.value += SeparadorDecimal + aux.substr(len – 2, len);
}
return false;
}
</script>
 

Exemplo de utilização:

<form>
Valor R$: <input type=”text” name=”valor” onKeyPress=”return(MascaraMoeda(this,’.’,’,’,event))”>
</form>