20 Stimmen

jQuery HTML-Tabellenspalte hinzufügen

Ich habe eine HTML-Tabelle wie diese:

<table border="1">
    <tbody>
        <tr>
            <td><a href="#" class="delete">DELETE ROW</a>COL 1</td>
            <td><a href="#" class="delete">DELETE COL</a>COL 2</td>
            <td><a href="#" class="delete">DELETE COL</a>COL 3</td>
            <td><a href="#" class="delete">DELETE COL</a>COL 4</td>
            <td><a href="#" class="delete">DELETE COL</a>COL 5</td>
            <td><a href="#" class="delete">DELETE COL</a>COL 6</td>
        </tr>
        <tr>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
        </tr>
        <tr>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
        </tr>
    </tbody>
</table>

Was ich brauche, ist eine Funktion zum Hinzufügen einer neuen Spalte mit einer Reihe von td's basierend auf anderen Spalten. Die Sache ist, dass in dieser HTML-Tabelle, Spalten mit jQuery entfernt werden, bevor neue Spalten hinzugefügt werden, so dass die Funktion die aktuelle Spaltenkonfiguration erhalten und entsprechend anpassen muss, weil die Zeilen und Spalten immer entfernt oder hinzugefügt werden.

Ich habe diesen Code zum Hinzufügen einer neuen Spalte, aber er fügt die Überschrift nicht hinzu:

function addACol() {
    var currentNumberOfTDsInARow = $('.tblModel tr:first td').length;
    newColNum = currentNumberOfTDsInARow;
    var rows = $('.tblModel tbody tr');
    for (var i = 0; i < rows.length; i++) {
        var lastTDClone = $(rows[i]).find('td:last').clone();
        $(rows[i]).find('td:last').after(lastTDClone);
    }
}

44voto

Sampson Punkte 258265

Update...

var c = $("#myTable tr:first td").length;
$("#myTable tr:first").append("<td><a href=''>Delete</a> Col "+(c+1)+"</td>");
$("#myTable tr:gt(0)").append("<td>Col</td>");

Wenn Sie die Nummerierung in den Titeln korrigieren müssen, können Sie die Funktion, an der wir in Ihrer vorherigen Frage gearbeitet haben .

Original-Antwort...

$("#myTable tr").append("<td>New Column</td>");

Wenn Sie auch eine Kopfzeile hinzufügen möchten, können Sie die vorherige Zeile auf alle TR größer als 0 beschränken:

$("#myTable tr:gt(0)").append("<td>New Column</td>");

Und die Überschrift würde nur auf dem ersten TR stehen:

$("#myTable tr:first").append("<td>Delete Column LINK</td>");

10voto

SolutionYogi Punkte 30824

Das hat zwar nichts mit Ihrer Frage zu tun, aber Sie können Ihr HTML etwas semantischer gestalten.

<table border="1">
    <thead>
        <tr>
            <th><a href="#" class="delete">DELETE ROW</a>COL 1</th>
            <th><a href="#" class="delete">DELETE COL</a>COL 2</th>
            <th><a href="#" class="delete">DELETE COL</a>COL 3</th>
            <th><a href="#" class="delete">DELETE COL</a>COL 4</th>
            <th><a href="#" class="delete">DELETE COL</a>COL 5</th>
            <th><a href="#" class="delete">DELETE COL</a>COL 6</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
            <td>ROW 1</td>
        </tr>
        <tr>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
            <td>ROW 2</td>
        </tr>
    </tbody>
</table>

Geänderter jQuery-Code kann wie folgt aussehen:

var c = $("#myTable thead th").length;
$("#myTable thead tr").append("<th><a href=''>Delete</a> Col "+(c+1)+"</th>");
$("#myTable tr:gt(0)").append("<td>Col</td>");

CodeJaeger.com

CodeJaeger ist eine Gemeinschaft für Programmierer, die täglich Hilfe erhalten..
Wir haben viele Inhalte, und Sie können auch Ihre eigenen Fragen stellen oder die Fragen anderer Leute lösen.

Powered by:

X