Restrição //Repositório JavaScript
Descrição
Classe para mascarar inputs e restringir caracteres.
Criado: 2005.10.08 - Modificado 2013.09.17
Criado: 2005.10.08 - Modificado 2013.09.17
Dependências
Código (Download)
//+ Carlos R. L. Rodrigues
//@ http://jsfromhell.com/forms/restrict [rev. #2]
Restrict = function(form){
this.form = form, this.field = {}, this.mask = {};
}
Restrict.field = Restrict.inst = Restrict.c = null;
Restrict.prototype.start = function(){
var $, __ = document.forms[this.form], s, x, j, c, sp, o = this, l;
var p = {".":/./, w:/\w/, W:/\W/, d:/\d/, D:/\D/, s:/\s/, a:/[\xc0-\xff]/, A:/[^\xc0-\xff]/};
for(var _ in $ = this.field)
if(/text|textarea|password/i.test(__[_].type)){
x = $[_].split(""), c = j = 0, sp, s = [[],[]];
for(var i = 0, l = x.length; i < l; i++)
if(x[i] == "\\" || sp){
if(sp = !sp) continue;
s[j][c++] = p[x[i]] || x[i];
}
else if(x[i] == "^") c = (j = 1) - 1;
else s[j][c++] = x[i];
o.mask[__[_].name] && (__[_].maxLength = o.mask[__[_].name].length);
__[_].pt = s, addEvent(__[_], "keydown", function(e){
var r = Restrict.field = e.target;
if(!o.mask[r.name]) return;
r.l = r.value.length, Restrict.inst = o; Restrict.c = e.key;
setTimeout(o.onchanged, r.e = 1);
});
addEvent(__[_], "keyup", function(e){
(Restrict.field = e.target).e = 0;
});
addEvent(__[_], "keypress", function(e){
o.restrict(e) || e.preventDefault();
var r = Restrict.field = e.target;
if(!o.mask[r.name]) return;
if(!r.e){
r.l = r.value.length, Restrict.inst = o, Restrict.c = e.key || 0;
setTimeout(o.onchanged, 1);
}
});
}
}
Restrict.prototype.restrict = function(e){
var o, c = e.key, n = (o = e.target).name, r;
var has = function(c, r){
for(var i = r.length; i--;)
if((r[i] instanceof RegExp && r[i].test(c)) || r[i] == c) return true;
return false;
}
var inRange = function(c){
return has(c, o.pt[0]) && !has(c, o.pt[1]);
}
return (c < 30 || inRange(String.fromCharCode(c))) ?
(this.onKeyAccept && this.onKeyAccept(o, c), !0) :
(this.onKeyRefuse && this.onKeyRefuse(o, c), !1);
}
Restrict.prototype.onchanged = function(){
var ob = Restrict, si, moz = false, o = ob.field, t, lt = (t = o.value).length, m = ob.inst.mask[o.name];
if(o.l == o.value.length) return;
if(si = o.selectionStart) moz = true;
else if(o.createTextRange){
var obj = document.selection.createRange(), r = o.createTextRange();
if(!r.setEndPoint) return false;
r.setEndPoint("EndToStart", obj); si = r.text.length;
}
else return false;
for(var i in m = m.split(""))
if(m[i] != "#")
t = t.replace(m[i] == "\\" ? m[++i] : m[i], "");
var j = 0, h = "", l = m.length, ini = si == 1, t = t.split("");
for(i = 0; i < l; i++)
if(m[i] != "#"){
if(m[i] == "\\" && (h += m[++i])) continue;
h += m[i], i + 1 == l && (t[j - 1] += h, h = "");
}
else{
if(!t[j] && !(h = "")) break;
(t[j] = h + t[j++]) && (h = "");
}
o.value = o.maxLength > -1 && o.maxLength < (t = t.join("")).length ? t.slice(0, o.maxLength) : t;
if(ob.c && ob.c != 46 && ob.c != 8){
if(si != lt){
while(m[si] != "#" && m[si]) si++;
ini && m[0] != "#" && si++;
}
else si = o.value.length;
}
!moz ? (obj.move("character", si), obj.select()) : o.setSelectionRange(si, si);
}
Exemplo (Exemplo)
<form id="form" action=" " method="post">
<input type="text" name="a" maxlength="10" /><br />
Restri??o = (\\d/) Somente n?meros e "/"<br />M?scara = ##/##/####<br /><br />
<input type="text" name="b" maxlength="14" /><br />
Restri??o = (\\d.-) Somente n?meros, ponto e h?fen<br />M?scara = ###.###.###-##<br /><br />
<textarea name="c" cols="4" rows="5" style="width: 300px; height: 120px;"></textarea><br />
Restri??o = (a\\^bc) Somente os caracteres "a", "b", "c" e "^"
</form>
<script type="text/javascript">
//<![CDATA[
var r = new Restrict("form");
r.field.a = "\\d/";
r.mask.a = "##/##/####";
r.field.b = "\\d.-";
r.mask.b = "###.###.###-##";
r.field.c = "a\\^bc";
r.onKeyRefuse = function(o, k){
o.style.backgroundColor = "#fdc";
}
r.onKeyAccept = function(o, k){
if(k > 30)
o.style.backgroundColor = "transparent";
}
r.start();
//]]>
</script>
Ajuda
Construtor
- Restrict(form: String)
-
Gera uma instância de Restrict.
- form
- nome ou id do formulário que receberá as validações
Propriedades
- Restrict.mask: Object
-
Esta propriedade serve para adicionar máscara aos campos e, deve ser usada da seguinte forma:
instanciaDeRestrict.mask.nomeDoCampoNoFormulario = mascara
.
Onde mascara segue as seguintes regras:-
A classe substitui cada caracter "#" na máscara pelo que for pressionado pelo usuário.
Ex:mascara = "##/##/####"
(para mascarar uma data) - Como o caracter "#" é de uso especial, se você precisar utilizar ele como parte da máscara, basta "comentá-lo" com "\\", ex: "\\#".
- A máscara é aplicada da esquerda para a direita, sendo assim, se o campo contiver menos caracteres que a máscara, os caracteres "extras" da máscara serão ignorados.
- Se a string contiver mais caracteres que a máscara, os caracteres restantes são simplesmente adicionados ao fim da máscara.
-
A classe substitui cada caracter "#" na máscara pelo que for pressionado pelo usuário.
- Restrict.field: Object
-
Esta propriedade serve para filtrar os caracteres que podem ser inseridos no campo.
Deve ser usada da seguinte forma:instanciaDeRestrict.field.nomeDoCampoNoFormulario = filtro
.
Onde filtro segue as seguintes regras:-
O filtro é aplicado apenas caracter que foi pressionado e, ele é de simples manuseio, apenas digite os caracteres que você
quer permitir.
Ex:filtro = "9aA."
(permitirá a digitação dos caracteres "9", "a", "A", e ".") -
No entanto, seria trabalhoso digitar todos os caracteres do alfabeto em um campo que deve permitir apenas letras,
portanto, há expressões regulares de filtragem pré-definidas na classe, são elas:
- "." = Qualquer caracter
- "w": Somente A-z, a-z, 0-9 e _
- "W": Qualquer caracter, exceto: A-z, a-z, 0-9 e _
- "d": 0-9
- "D": Qualquer caracter, exceto 0-9
- "s": Permite espaço em branco, tabulação, quebra de linha, etc (\f\n\r\t\v)
- "a": Permite somente letras acentuadas
- "A": Permite qualquer caracter, exceto letras acentuadas
Se precisar de mais regras, basta definí-las no código fonte.
Para utilizar, basta prefixar o nome da regra com "\\".
Ex:filtro = "\\d\\s"
(permite números e espaços) -
Também é possível especificar exceções para o filtro usando o caracter "^".
Ex:filtro = "\\d^123" (permite 0-9, menos os caractes 1, 2 e 3)
-
A barra "\\" e o "^" são considerados caracteres especiais no filtro, se precisar utilizá-los, faça como no exemplo abaixo.
Ex:filter = "\\\\"
(permite a barra invertida)filter = "\\^"
(permite o cincunflexo)
-
O filtro é aplicado apenas caracter que foi pressionado e, ele é de simples manuseio, apenas digite os caracteres que você
quer permitir.
Métodos
- Restrict.start(void): void
- Inicia o objeto. Deve ser chamado depois que todas as regras já estiverem devidamente setadas.
Eventos
- Restrict.onKeyRefuse: function(field: HTMLInputElement, keyCode: Integer): void
-
Este evento é chamado sempre que o usuário digitar um caracter inválido.
- field
- campo que está sendo editado
- keyCode
- código do caracter pressionado
- Restrict.onKeyRefuse: function(field: HTMLInputElement, keyCode: Integer): void
-
Este evento é chamado sempre que o usuário digitar um caracter válido.
- field
- campo que está sendo editado
- keyCode
- código do caracter pressionado
Ranque (Votos: 94)
4.20