Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to get data-attr when click table row

I have table and I want to get a data attribute of column "geometry" of the row which is clicked. So what I am doing is:

var row = jQuery(this).closest("tr");  

Above code is to get that row which is clicked and the below code is to get data attribute from column geometry, my data attribute is data-geomet.

var text = row.find("geometry").data("geomet");
console.log(text);

I am getting text undefined. I get text() of class geometry but could not get data attribute.

Example HTML:

<td class="geometry" data-geomet="${obj["Details"]}"> details["geometry"]</td></tr>

UPDATE

    %for obj in tableData:
        var details=JSON.parse('${obj["Details"]}');
        var data = "<tr><td> <a href='#gMap' class='fence_data'>${obj['Geofence_Name']}</a></td>";
        data += "<td>${obj['Vehicle_Id']}</td>";
        if(details["type"]===undefined){
            data += '<td>NA</td>';  
        }
        else{
            data += '<td class="type"> '+details["type"]+'</td>';
        }
        if(details["radius"]===undefined){
            data += '<td>NA</td>';  
        }
        else{
            data+='<td class="radius"> '+details["radius"]+'</td>';
        }
        if(details["geometry"]===undefined){
            data += '<td>NA</td></tr>'; 
        }
        else{
            data += '<td class="geometry" data-geomet="${obj["Details"]}"> '+details["geometry"]+'</td></tr>';
        }
       table.append(data)

    %endfor

Here is an example jsfiddle.net/3vmL5277/2 where I am getting undefined.

like image 534
CY5 Avatar asked Sep 03 '25 04:09

CY5


1 Answers

Given your HTML in this format:

<td class="geometry" data-geomet="${obj["Details"]}"> details["geometry"]</td></tr>

This code should work for you:

// assuming this code is in an event handler
// and 'this' refers to an element within a 'tr' element
var $row = jQuery(this).closest("tr");
var text = $row.find(".geometry").data("geomet");
console.log(text);
like image 140
Rory McCrossan Avatar answered Sep 05 '25 00:09

Rory McCrossan