Skip to content Skip to sidebar Skip to footer

Append Table Array Value To Another Array

I have this code below that popups the cell value whenever the user clicks a specific cell. What I'm currently trying to do is when the user clicks a cell i want that cell value to

Solution 1:

Restructure your code to have a method to redraw UI and to enable event listeners:

functionredraw (obj) {

  var $header = $('<tr>'),
    cols = 0,
    bodyString = ''

  $.each(obj, function (key, values) {
    cols = Math.max(cols, values.length) // find the longest
    $header.append($('<th/>').text(key + ': ' + values.length))
  })
  for (var i = 0; i < cols; i++) { // or use .map, but this is more undertandable for beginners
    bodyString += '<tr>'
    $.each(obj, function (key, values) {
      bodyString += '<td>' +
        (values[i] ? values[i] : '') + // ternary - instead of using if/else'</td>'
    })
    bodyString += '</tr>'
  }
  $('.fruitsTableClass thead').html($header)
  $('.fruitsTableClass tbody').html(bodyString)
}

functionlistener (obj) {
  tbl = document.getElementById('fruitsTable')
  if (tbl != null) {
    for (var i = 0; i < tbl.rows.length; i++) {
      for (var j = 0; j < tbl.rows[i].cells.length; j++)
        tbl.rows[i].cells[j].onclick = function () {
          getval(this)
          obj[key2].push(this.innerHTML)
          redraw(obj)
          listener(obj)
        };
    }
  }
}

functiongetval (cel) {
  alert(cel.innerHTML)
}

redraw(obj)
listener(obj)

JSFiddle - https://jsfiddle.net/gnm8wv5f/

Solution 2:

To add rows or cells to a table, you should use the methods insertRow() and insertCell().

Example, if you want to add a cell at the beginning of a row (from w3schools):

var row = document.getElementById("myRow");
var x = row.insertCell(0);
x.innerHTML = "New cell";

Or, to insert at the end:

var x = row.insertCell(row.cells.length);

Using cells.length you can find the number of cells in a particluar row, in that way you could know where to insert the new cell.

More info in: w3 | MDN

Solution 3:

Try this code.

<html><head><scriptsrc="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script><script>var daraArray=[];   
$(document).ready(function(){
    $(".classTd").click(function(){
       //console.log($(this).html());
       daraArray.push($(this).html());
       console.log(daraArray);
    });
});
</script><styletype="text/css">.classTd{
        text-align: center;
    }
</style></head><tableid="fruitsTable"class="fruitstableroni skillsTable class"border="1"><thead></thead><tbody><tr><tdclass="classTd"width="10%">1</td><tdclass="classTd"width="10%">2</td><tdclass="classTd"width="10%">3</td></tr><tr><tdclass="classTd"width="10%">4</td><tdclass="classTd"width="10%">5</td><tdclass="classTd"width="10%">6</td></tr><tr><tdclass="classTd"width="10%">7</td><tdclass="classTd"width="10%">8</td><tdclass="classTd"width="10%">9</td></tr></tbody></table></html>

Solution 4:

The other answers here are good but you should definitely try AngularJs. The ng-repeat tag will easily cater your functionality.

Post a Comment for "Append Table Array Value To Another Array"