I have a dynamic table that I want to attach
elements with jQuery.
I have this:
var tds = jQuery(\"tr > td\").length; //
With a loop :
var $col = $("#colgroup-compare > col");
for(var i = 0; i < n; i++){
$col.clone().appendTo('#colgroup-compare');
}
You can't use jQuery("#colgroup-compare > col").clone().appendTo('#colgroup-compare');
in your loop because that would append more cols at iterations > 0...
This can be optimized :
var $colgroup = $('#colgroup-compare'); // this saves the colgroup collection to avoid recomputing it later
var $col = $colgroup.children("col"); // this makes the clonable col(s) from the col children of $colgroup
for (var i=n; i-->0;){ // n times (from n-1 to 0)
$colgroup.append($col.clone()); // append a clone of the col(s)
}
EDIT : to count the th
in your first row, you may do this :
var n=$("tr").first().children('th').length;
(this avoid counting on more than one row)
Demonstration
If you don't want deep clones, then you can avoid the manual iteration by passing the outerHTML of the element to an arrays join() method resulting in an HTMLString corresponding to n
number of elements as shown below:
var elementString = new Array(++n).join($(selector).get(0).outerHTML)
which you can append to any element you wish.
In your case you can do:
var n= $("tr > td").length,
$colgroup = $("#colgroup-compare");
$colgroup.append(new Array(++n).join($colgroup.find("col").get(0).outerHTML));