Create event click for dynamic button

0

I'm dynamically adding rows to a table, but I can not seem to make the dynamically-created button work.

Below is the section where I create an ajax request to add a row in my table:

    $("#btnitemproduto").click(function(){
        var xmlhttp = new XMLHttpRequest();
        var hash = document.getElementById("inputHash").value;
        var e = document.getElementById("produtos");
        var produto = e.options[e.selectedIndex].value;
        var produtodescr = e.options[e.selectedIndex].text;
        var qtd = $("#inputQuantidade").val();
        var embalagem = $("#inputEmbalagem").val();
        var precokg = $("#inputPrecoKg").val();
        var precooriginal = document.getElementById("inputPrecoOriginal").value;
        var precototal = $("#inputPrecoTotal").val();
        var precosaco = $("#inputPrecoSaco").val();

            $.post("itempedido.php",
            {
                hash: hash,
                produto: produto,
                quantidade: qtd,
                embalagem: embalagem,
                precokg: precokg,
                precooriginal: precooriginal,
                precototal: precototal,
                produtodescr: produtodescr,
                precosaco: precosaco
            },
            function(data, status){
                if(jQuery.trim(data)!=""){
                    $('#tblitens > tbody:last').append(data);
                    var x = $("#inputValorTotal").val();
                    var y = parseFloat(precototal.replace('.','').replace(',','.')) +  parseFloat(x);
                    $("#inputValorTotal").val(y);
                    x = "R$ " + y.toFixed(2).replace(".", ",").replace(/(\d)(?=(\d{3})+(?!\d))/g, "$1.");
                    $("#sum").html("Valor Total: "+x);
                }else{
                    alert("Atenção! Você já adicionou este produto ao pedido!");
                }
            });
        }); 

HTML excerpt that I add inside the table (return from the ordered item.php):

<tr>
    <td class="col-sm-5"><b>'.$produtodescr.'</b></td>
    <td class="col-sm-1 text-center"><b>'.$quantidade.'</b></td>
    <td class="col-sm-1 text-right"><b>'.$embalagemp.'</b></td>
    <td class="col-sm-1 text-right"><b>'.$precokgp.'</b></td>
    <td class="col-sm-1 text-left"><b>'.$fontend.'</b></td>
    <td class="col-sm-1 text-right"><b>'.$precosaco.'</b></td>
    <td class="col-sm-1 text-right"><b>'.$precototalv.'</b></td>
    <td class="col-sm-1 text-center">
       <button id="btndeleteitem" name="btndeleteitem" type="button" class="btn btn-default btn-xs" data-id="'.$hash.'" data-idproduct="'.$produto.'" >        <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>Excluir</button></td>
</tr>

Alert that should be displayed when you click the button:

    $("#tblitens").on("click", ".btndeleteitem", function(e) {
        alert("Teste!");
    });
    
asked by anonymous 30.04.2017 / 18:14

1 answer

0

I imagine the problem is with using the .btndeleteitem class instead of the id #btndeleteitem. Fixing stays:

$("#tblitens").on("click", "#btndeleteitem", function(e) {
        alert("Teste!");
});
    
30.04.2017 / 23:16