Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

malukovynsk

Alguém sabe resolver?

Recommended Posts

Tudo bem pessoal? então tem um probleminha no meu código e eu não consigo solucionar:

é assim, é uma caixa de formulário que filtra somente os números de telefone:

Por exemplo se eu colocar nela o seguinte conteúdo: valido | outro | invalido (99)985292963 valido | outro | invalido (99)985292963 valido | outro | invalido (99)985292963 valido | outro | invalido (99)985292963 

 

ele vai filtrar assim: (99)98529-2963 /(99)98529-2963 /(99)98529-2963 /(99)98529-2963 

 

Até ai tudo bem, mas se eu colocar um conteúdo que tenha outros números separados sem ser o de telefone ele nao filtra, ele apaga tudo.

 

exemplo: (99)98529-2963 n chama 2 vezes/ (99)98529-2963 caixa postal 2 vezes /

 

Em vez de ele apagar o numero 2 que não é em formato de telefone ele exclui tudo.

 

Então eu queria que vocês me ajudassem nessa questão, se tiver numero separado sem ser no formato de telefone, tanto celular e fixo ele apagasse esses numeros e deixasse somente os de telefone...

 

tem como?

<script>
    function filtrarNumeros() {
        var value = $('#areaFiltro').val();
        var caracteresValidos = /[^0-9()-]/gi;
        var cont = 0;

        var space = document.createTextNode("\u00A0");

        var res = value.split('(');

        var numerosInvalidos = [];
        var numerosValidos = [];

        for(var t = 0; t<res.length; t++){
            res[t] = "("+res[t];
            if(res[t].length == 14) {
                res1 = res[t].slice(0,10);
                res2 = res[t].slice(10,14);
                console.log(res[t].slice(9,10) );
                if(res[t].slice(9,10) == '-') {
                    numerosValidos.push(res1 + res2);
                }else {
                    numerosValidos.push(res1 + '-' + res2);
                }
            }
            else if(res[t].length == 13) {
                res1 = res[t].slice(0,9);
                res2 = res[t].slice(9,13);
                console.log(res[t].slice(8,9) );
               if(res[t].slice(8,9) == '-') {
                   numerosValidos.push(res1 + res2);
               }else {
                   numerosValidos.push(res1 + '-' + res2);
               }
            }
            else if(res[t].length == 12) {
                res1 = res[t].slice(0,8);
                res2 = res[t].slice(8,12);
                console.log(res[t].slice(7,8) );
                if(res[t].slice(7,8) == '-') {
                    numerosValidos.push(res1 + res2);
                }else {
                    numerosValidos.push(res1 + '-' + res2);
                }
            }
            /*
            else if(res[t].length == 9) {
                res1 = res[t].slice(0,5);
                res2 = res[t].slice(5,9);
                console.log(res1+'-'+res2);
            }
            else if(res[t].length == 8) {
                res1 = res[t].slice(0,4);
                res2 = res[t].slice(4,8);
                console.log(res1+'-'+res2);
            }*/
            else{
                numerosInvalidos.push(res[t]);
                //swal("Ops","Algum dado está errado no filtro, Verifique e tente novamente","warning");
            }

        }

        console.log('Inválido:', numerosInvalidos);
        console.log('Válido:', numerosValidos);


        if(caracteresValidos.test(value) || !caracteresValidos.test(value)){
            value = value.replace(caracteresValidos, "");

            for(var x=0; x<value.length;x++){

                if(value[x] == ')'){
                    cont = cont + 1;
                }
            }


            //document.getElementById("areaFiltro").value = value;
            document.getElementById("areaFiltro").value = numerosValidos;
            document.getElementById("areaFiltro").focus();
            document.getElementById("areaFiltro").select();
            document.getElementById("btnCopiar").disabled = false;
            $("#btnCopiar").click(function(){
                $("textarea").select();
                document.execCommand('copy');
            });

            document.getElementById("rowTotal").hidden = false;
            document.getElementById("cont").value = cont;
        }
        if(value == '') {
            console.log(caracteresValidos.test(value));
            swal("Ops!", "Preencha o campo!", "warning")
        }
    }
</script>
--}}

<script>
    function filtrarNumeros() {

        var value = $('#areaFiltro').val();
        var caracteresValidos = /[^0-9()-]/gi;
        var cont = 0;

        if (caracteresValidos.test(value) || !caracteresValidos.test(value)) {
            value = value.replace(caracteresValidos, "");

            for (var x = 0; x < value.length; x++) {
                if (value[x] == ')') {
                    cont = cont + 1;
                }
            }

            /////
            var res = value.split('(');

            var numerosInvalidos = [];
            var numerosValidos = [];

            for (var t = 0; t < res.length; t++) {
                res[t] = "(" + res[t];
                if (res[t].length == 14) {
                    res1 = res[t].slice(0, 10);
                    res2 = res[t].slice(10, 14);
                    console.log(res[t].slice(9, 10));
                    if (res[t].slice(9, 10) == '-') {
                        numerosValidos.push(res1 + res2 + " ");
                    } else {
                        numerosValidos.push(res1 + '-' + res2 + " ");
                    }
                }
                else if (res[t].length == 13) {
                    res1 = res[t].slice(0, 9);
                    res2 = res[t].slice(9, 13);
                    console.log(res[t].slice(8, 9));
                    if (res[t].slice(8, 9) == '-') {
                        numerosValidos.push(res1 + res2 + " ");
                    } else {
                        numerosValidos.push(res1 + '-' + res2 + " ");
                    }
                }
                else if (res[t].length == 12) {
                    res1 = res[t].slice(0, 8);
                    res2 = res[t].slice(8, 12);
                    console.log(res[t].slice(7, 8));
                    if (res[t].slice(7, 8) == '-') {
                        numerosValidos.push(res1 + res2 + " ");
                    } else {
                        numerosValidos.push(res1 + '-' + res2 + " ");
                    }
                }
                /*
                 else if(res[t].length == 9) {
                 res1 = res[t].slice(0,5);
                 res2 = res[t].slice(5,9);
                 console.log(res1+'-'+res2);
                 }
                 else if(res[t].length == 8) {
                 res1 = res[t].slice(0,4);
                 res2 = res[t].slice(4,8);
                 console.log(res1+'-'+res2);
                 }*/
                else {
                    numerosInvalidos.push(res[t]);
                    //swal("Ops","Algum dado está errado no filtro, verifique e tente novamente","warning");
                }

            }

            //console.log('Inválido:', numerosInvalidos);
            //console.log('Válido:', numerosValidos);
            ///////////

            document.getElementById("areaFiltro").value = numerosValidos.join('/');
            document.getElementById("areaFiltro").focus();
            document.getElementById("areaFiltro").select();
            document.getElementById("btnCopiar").disabled = false;
            $("#btnCopiar").click(function () {
                $("textarea").select();
                document.execCommand('copy');
            });

            document.getElementById("rowTotal").hidden = false;
            document.getElementById("cont").value = cont;
        }
        if (value == '') {
            console.log(caracteresValidos.test(value));
            swal("Ops!", "Preencha o campo!", "warning")
        }
    }
</script>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 24/05/2017 at 17:01, malukovynsk disse:

Obrigado Rapadura, mas eu não consegui... será que você não poderia mexer no codigo pra mim por favor, entendo pouco dessa linguagem! :tired:

 

Dá uma olhada nessa expressão regular para formatar o telefone

([0-9\(\)]){4}([0-9]){5}[-]([0-9]){4}

Agora cria uma validação ou uma máscara no campo que que a informação ou seja, o número entre dessa forma:  (99)99999-9999

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.