Ir para conteúdo

Arquivado

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

Viniiciiu Spinellis

Pegar valor do submit do <tr>

Recommended Posts

Pessoal bom dia.

 

Minha dúvida é basicamente a seguinte: Tenho uma tabela que tem um submit para cada linha, o submit enviar pro jquery que faz o update. Não estou conseguindo fazer o jquery identificar qual o submit que eu cliquei, sempre vai o valor do primeiro.

 

Segue o código:

$(function($) {
	// Quando o formulário for enviado, essa função é chamada
	$("#aloctec").submit(function() {
		// Colocamos os valores de cada campo em uma váriavel para facilitar a manipulação
		var customer = $("#customer option:selected").val();
		var id_serv = $("#id_serv").val();
		
		// Exibe mensagem de carregamento
		$("#status").html(id_serv);
		// Fazemos a requisão ajax com o arquivo envia.php e enviamos os valores de cada campo através do método POST
		$.post('aloctec.php', {customer: customer, id_serv:id_serv }, function(resposta) {
			data: $("form#"+id).serialize()
				// Quando terminada a requisição
				// Exibe a div status
				$("#status").slideDown();
				// Se a resposta é um erro
				if (resposta != false) {
					// Exibe o erro na div
					$("#status").html(resposta);
				} 
				$("#status").hide("slow");
				return false;
		});
	});
});
</script>

 		<form id="aloctec" action="javascript:func()" method="post">
        <table class="as_gridder_table" width="100%" style="font-size:10px">
        <thead>
            <tr class="grid_header">
                <td><div class="grid_heading">Id</div></td>
                <td><div class="grid_heading">Assinante</div></td>
                <td><div class="grid_heading">Região</div></td>
                <td><div class="grid_heading">Técnico</div></td>
                <td><div class="grid_heading">Serviço</div></td>
                <td><div class="grid_heading">Período</div></td>
                <td><div class="grid_heading">Agendamento</div></td>
                
                
            </tr>
            </thead>
             <tbody>
                      <?php
            if($count <= 0) {
            ?>
         
            <tr id="norecords">
                <td align="center">Nenhuma os para hoje</td>
            </tr>
          
            <?php }else{
			while($dadoss= mysql_fetch_array($queryss)){
			?>
           
            <tr>
           
                <td><?php echo $dadoss['id_servico']; ?></td>
                <td><?php echo $dadoss['nome_assinante']; ?></td>
                <td><?php echo $dadoss['regiao_servico']; ?></td>
                <td>
               
                <div id="status"></div>
                <select id="customer">
                <option selected="selected">Selecione</option>
                <?php 
				$pegdados = mysql_query("SELECT * FROM tecnicos");
				while($dados = mysql_fetch_array($pegdados)){
				?>
                <option><?php echo $dados['NomeAbrev']; ?></option>
                <?php }; ?>
                </select>
                <input type="hidden" value="<?php echo $dadoss['id_servico']; ?>" id="id_serv" />
                <input type="submit" value="ALC" />
                
                </td>
                <td><?php echo $dadoss['tipo_servico']; ?></td>
                <td><?php echo $dadoss['periodo_agendado']; ?></td>
                <td><?php echo $dadoss['confimado_agendamento']; ?></td>
                
            </tr>
           <?php
		      };
			  };
			  ?> 
           
            </tbody>
            </table>
            </form>

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olá, Viniiciiu.

 

O atributo id só pode ter um elemento por página com o mesmo valor. Como está é a regra quando você faz:

$(#id_serv);

assim que o jQuery acha o primeiro elemento ele não continua verificando se tem mais elementos com o id=id_serv.

Se você quer pegar elementos com o mesmo valor o atributo que você tem que utilizar no HTML é class.

 

Troca o atributo id dessa linha:

<input type="hidden" value="<?php echo $dadoss['id_servico']; ?>" id="id_serv" />

por class:

<input type="hidden" value="<?php echo $dadoss['id_servico']; ?>" class="id_serv" /> 

Depois altere seu JavaScript, pra deixar de pegar o elemento pelo id:

var id_serv = $("#id_serv").val();

e pegar pela class:

var id_serv = $(".id_serv").val();

Espero que resolva, se não resolver avisa que dou uma olhada melhor no código. :-)

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por Carcleo
      Estou começando no Laravel 11 e me deparei com um problema de belongsTo
       
      public function listOfClass(Request $request, StudentDisciplineClassroom $sdc) : ?string {         $all = $sdc::select('student')->with('studentRelation')->where('classroom',$request->classroom)->distinct('student')->get();     dd($all->toArray());     $students = [];     foreach ($all as $student) {             $students[] =$student;     }       return response()->json($students)->getContent();     } isso

      Em studentRelation temos na tabela StudentDisciplineClassroom com os campos

      id(chave primaria)
      ra (chave estrangera que referencia o campo academic_registration na tabela de students)

      e a tabela student tem os campos

      id (chave primária)
      academic_registration (que vai ser refeenciada na tabela StudentDisciplineClassroom

      Mas na hora de fazer
      $sdc::select('student')->with('studentRelation')->where('classroom',$request->classroom)->distinct('student')->get();
      O studentRelation retorna nulo

      Onde eu posso estar errando?
    • Por joao b silva
      Tenho uma pequena aplicação em php que gera arquivos pdf com a MPDF e envia email com a PHPMAILER. De repente a app parou de enviar os emails  e apresenta a seguinte mensagem de erro:
       
      Error PHPMailer: SMTP Error: Could not authenticate.
       
      Faço uso de um hotmail para a configuração do PHPMAILER.
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos.
       
      Quando programava em DOS. utilizava algumas teclas de atalho para: SALVAR / EDITAR / EXCLUIR / IMPRIMIR.
      Por exemplo:
      Salvar ----> ALT+S
      Editar ----> ALT+E
      Excluir --> ALT+X
      Imprimir -> ALT+I

      no PHP tem como colocar esses ATALHOS nos button, para o usuário trabalhar com esses atalhos e como seria ?

      grato,
       
      Cesar
    • Por violin101
      Caros Amigos, saudações.
       
      Por favor, me perdoa em postar uma dúvida.
       
      Preciso criar uma Rotina onde o usuário possa buscar na Base de Dados de Produtos, tanto por Código e Descrição, ou seja:
      - caso o usuário digita o Código, mostra os dados do Produto.
      - caso o usuário digita a Descrição, mostra os dados do Produto
       
      Fiz uma Rotina, onde o usuário digita a DESCRIÇÃO com a função AUTOCOMPLETE.    <=== está funcionando certinho.
       
      Minha dúvida é como faço para DIGITAR o Código e mostrar os dados também.
       
      o meu AutoComplete na MODEL está assim.
      public function autoCompleteProduto($q){ $this->db->select('*' ) ->from('produtos') ->where('produtos.statusProd',1) ->like('descricao', $q) ->limit(5) ->order_by('descricao', 'ASC'); $query = $this->db->get(); if ($query->num_rows() > 0) { foreach ($query->result_array() as $row) { $row_set[] = ['label' => str_pad($row['idProdutos'], '5', '0', STR_PAD_LEFT).' - '.$row['descricao'], 'id' => $row['idProdutos'], 'descricao' => $row['descricao'], 'cod_interno' => $row['cod_interno'], 'prd_unid' => $row['prd_unid'], 'estoque_atual' => $row['estoque_atual'] ]; } echo json_encode($row_set); } }  
       
      no CONTROLLER está assim:
      public function autoCompleteProduto() { $this->load->model('estoque/lancamentos_model'); if (isset($_GET['term'])) { $q = strtolower($_GET['term']); $this->lancamentos_model->autoCompleteProduto($q); } }  
       
      na VIEW está assim:
      <div class="col-md-10"> <label for="idProdutos">Produto:</label> <input type="hidden" name="idProdutos" id="idProdutos"> <input type="text" class="form-control" id="descricao" name="descricao" style="font-size:15px; font-weight:bold;" placeholder="Pesquisar por descrição do produto" disabled> </div>  
      VIEW + JAVASCRIPT
       
      //Função para trazer os Dados pelo o AutoComplete. function resolveAutocomplete() { $("#descricao").autocomplete({ source: "<?php echo base_url(); ?>estoque/lancamentos/autoCompleteProduto/", minLength: 2, select: function (event, ui) { $("#idProdutos").val(ui.item.id); $("#cod_interno").val(ui.item.cod_interno); $("#descricao").val(ui.item.descricao); $("#prd_unid").val(ui.item.prd_unid); $("#estoque_atual").val(ui.item.estoque_atual); $("#qtde").focus(); } }); } // inicia o autocomplete resolveAutocomplete();  
      Grato,
       
      Cesar
    • Por belann
      Olá!
       
      Estou tentando criar um projeto laravel e está dando o seguinte erro 
      curl error 60 while downloading https://getcomposer.org/versions: SSL certificate problem: unable to get local issu
        er certificate
      Já tentei atualizar o composer, mas dá o mesmo erro acima.
×

Informação importante

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