Ir para conteúdo

POWERED BY:

fideles

Ids em array

Recommended Posts

Senhores, um dúvida e acho que vocês podem me ajudar a exclarecer ou mudar o codigo.

 

Tenho um formulario onde pode acrescentar varias linhas com javascript e com um botão para chamar a função e que funciona bacana, codigo abaixo;

<script type="text/javascript">
$(function () {

  $(".adicionarCampo").click(function () {
	novoCampo = $("tr.linhas:first").clone();
	novoCampo.find("input").val("");
	novoCampo.insertAfter("tr.linhas:last");
	removeCampo();
  });
});
</script>

Tenho uma função em javascript também que faz preencher alguns campos automaticamente com base em um select.

<script type="text/javascript">
	
	function update(cod_atividade){
		$.post("scripts/codigos_atividades.php", {cod_atividade:cod_atividade}, function(retorno){
			
			dados = retorno.split("/");
			$('#descricao').val(dados[0]);
			
			//alert(dados[0]);
			
		});
}
	
</script>

 

O problema é que nos input, nos nomes eu coloquei colchetes no final, uma vez que eu tenho um array para gravar tudo de uma vez no banco.

<input name="descricao[]" type="text" required="required" id="descricao" size="45" maxlength="255" readonly="readonly" />

So  que no script acima, ele direciona os inputs pelo ID, como o ID é unico, como que eu faço para ele reconher cada linha acrecentada conforme o 1º JS?

 

Ex: 

Cliquei na primeira linha, selecionei uma opção no select e preencheu o campo descrição

Ao adicionar uma segunda linha, como o id é unico, ele não preenche, acaba alterando a primeira linha novamente.

 

Alguém sugere algo que eu consiga ele identificar cada linha acrescentada e preenche o campo daquela respectiva linha?

 

Obrigado desde já.

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

<div id="colocar_aqui"></div>

<button onclick="adicionarInput()">Novo Input</button>

<script>
    var contagemID = 0,
        maximoInput = 10, // Quantos podem ser adicionados?
        novoInput,
        novoButton,
        dataInput,
        removeInput,
        alvo = document.getElementById('colocar_aqui');

    function adicionarInput() {
        contagemID++;

        if (contagemID <= maximoInput) {
            // Criar novo input
            novoInput = document.createElement('input');
            novoInput.type = 'text';
            novoInput.name = 'descricao[]';
            novoInput.id = 'descricao_' + contagemID;
            alvo.appendChild(novoInput);

            // Remover input adicionado
            novoButton = document.createElement('button');
            novoButton.innerText = 'Remover';
            novoButton.setAttribute('data-input', novoInput.id);
            novoButton.addEventListener('click', removerInput, false);
            alvo.appendChild(novoButton);
        }
    }

    function removerInput(e) {
        dataInput = e.target;
        removeInput = document.getElementById((dataInput).dataset.input);
        removeInput.parentNode.removeChild(removeInput);
        dataInput.parentNode.removeChild(dataInput);
    }
</script>

 

#EDIT:

Veja que cada ID vai ser descricao_Numero_de_adição

Perceba também o uso do atributo data que você também pode usar para obter o elemento que queira atacar.

Pois foi esse o método que usei para saber qual item devo atacar com a função de remover.

 

 

Além do atributo data você pode usar um classificador e atingir diversos itens de uma só vez.

Qual informação será adicionada ao input, e quais os critérios para esse complemento não há como eu saber.

 

Seria de grande ajuda saber se existe algum critério para anexar valor a um elemento, e que valor seria esse.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá Omar, obrigado por ajudar.

 

O script de adicionar e remover campo, este funciona perfeitamente.

 

O script abaixo também funciona, só não funciona quando eu acrescento mais linha, ele continua sempre na primeira linha.

<script type="text/javascript">
	
	function update(cod_atividade){
		$.post("scripts/codigos_atividades.php", {cod_atividade:cod_atividade}, function(retorno){
			
			dados = retorno.split("/");
			$('#descricao').val(dados[0]);
			
			//alert(dados[0]);
			
		});
}
	
</script>

 

E é nesta parte que eu me perco. Ao clica no botão para adicionar linha, a linha é adicionada, mais o script acima so identifica o ID da primeira linha e as demais não funciona.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Lógico , que só o primeiro é alvo, justo porque um identificador é único não pode se repetir.

 

Por isso lhe mostrei uma função que irá criar um elemento em loop cada um com um id único.

Da mesma forma que mostrei como encontrar esse elemento no DOM.

 

Mas não só pelo #ID que podemos encontrar um elemento no documento, existem várias outras formas, e uma infinidade de abordagens diferentes, não importa se está no DOM pode ser encontrado.

 

Um método seria ao criar o elemento adicionar ao mesmo um classificador que poderá ser usado para localizar ele com mais facilidade.

Então um função poderá manipular esse(s) elemento(s). Vejamos isso na prática:

Spoiler

<div class="elemento_alvo">Alvo da função 1</div>
<div class="elemento_alvo">Alvo da função 2</div>
<div class="elemento_alvo">Alvo da função 3</div>
<div class="elemento_alvo">Alvo da função 4</div>
<div class="elemento_alvo">Alvo da função 5</div>
<div class="elemento_alvo">Alvo da função 6</div>

<button onclick="update();">Ativar Update</button>

<script>
    function update() {
        var retorno = 'Item 1/Item 2/Item 3/Item 4/Item 5',
            dados = retorno.split('/'),
            alvos = document.getElementsByClassName('elemento_alvo');
        for (var i = 0; i < alvos.length; i++) {
            alvos[i].innerText = dados[i];
        }
    }
</script>

 

 

Como o que vamos adicionar a cada elemento vem de um array dados, podemos saber seus índices com

dados[0], dados[1] etc..

Usando o método para localizar o classificador "elemento_avo" teremos um array da NodeList de todos

alvos[0], alvos[1] etc..

Bastando então executar um loop no array dos elementos podemos obter o índice da volta atual do loop através de uma variável que se alto incrementa a cada volta. 

 

Mas como nem tudo que reluz é ouro, problemas podem ocorrer se se a quantidade de itens no array dados for menor que o numero de elementos.

Para isso basta apenas conferir se exite algo para se manipular antes:

/*
for (var i = 0; i < alvos.length; i++) {
    alvos[i].innerText = dados[i];
}
*/
for (var i = 0; i < alvos.length; i++) {
    if (typeof dados[i] !== 'undefined' && dados[i] !== null) { // Adicionando esse checagem
        alvos[i].innerText = dados[i];
    }
}

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • 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
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
×

Informação importante

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