jQuery中最后一行向表中添加额外行的最佳方法是什么?
这可以接受吗?
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
您可以添加到这样的表格(例如输入,选择,行数)有限制吗?
答案 0 :(得分:2004)
您建议的方法无法保证为您提供您正在寻找的结果 - 例如,如果您有tbody
该怎么办:
<table id="myTable">
<tbody>
<tr>...</tr>
<tr>...</tr>
</tbody>
</table>
您最终会得到以下结果:
<table id="myTable">
<tbody>
<tr>...</tr>
<tr>...</tr>
</tbody>
<tr>...</tr>
</table>
因此我建议采用这种方法:
$('#myTable tr:last').after('<tr>...</tr><tr>...</tr>');
您可以在after()
方法中包含任何内容,只要它是有效的HTML,包括上面示例中的多行。
更新:在此问题的最近活动之后重新审核此答案。 eyelidless是一个很好的评论,在DOM中总会有tbody
;这是事实,但只有至少有一行。如果没有行,除非您自己指定了行,否则将不会有tbody
。
DaRKoN_ suggests附加到tbody
,而非在最后tr
之后添加内容。这解决了没有行的问题,但仍然不是防弹的,因为理论上你可以有多个tbody
元素,并且行会被添加到每个行中。
权衡一切,我不确定是否有单一的单线解决方案可以解决每一种可能的情况。您需要确保jQuery代码与您的标记一致。
我认为最安全的解决方案可能是确保您的table
始终在标记中包含至少一个tbody
,即使它没有行也是如此。在此基础上,您可以使用以下内容,但是您可以使用多行(并且还可以考虑多个tbody
元素):
$('#myTable > tbody:last-child').append('<tr>...</tr><tr>...</tr>');
答案 1 :(得分:736)
jQuery有一个内置的工具来动态操作DOM元素。
您可以像这样在表格中添加任何内容:
$("#tableID").find('tbody')
.append($('<tr>')
.append($('<td>')
.append($('<img>')
.attr('src', 'img.png')
.text('Image cell')
)
)
);
jQuery中的$('<some-tag>')
是一个标记对象,可以有多个attr
属性可以设置和获取,以及text
,它代表标记之间的文本:<tag>text</tag>
。
这是一些非常奇怪的缩进,但是你更容易看到这个例子中发生了什么。
答案 2 :(得分:291)
自@Luke Bennett回答这个问题以来,情况发生了变化。这是一个更新。
jQuery版本1.4(?)自动检测您尝试插入的元素(使用append()
,prepend()
,before()
或after()
方法中的任何一种)是<tr>
并将其插入表格中的第一个<tbody>
,或者如果不存在,则将其包装到新的<tbody>
中。
所以是的,您的示例代码是可以接受的,并且可以与jQuery 1.4+一起使用。 ;)
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
答案 3 :(得分:159)
如果您有<tbody>
和<tfoot>
怎么办?
如:
<table>
<tbody>
<tr><td>Foo</td></tr>
</tbody>
<tfoot>
<tr><td>footer information</td></tr>
</tfoot>
</table>
然后它会在页脚中插入新行 - 而不是在正文中。
因此,最佳解决方案是添加<tbody>
代码并使用.append
,而不是.after
。
$("#myTable > tbody").append("<tr><td>row content</td></tr>");
答案 4 :(得分:58)
我知道你要求使用jQuery方法。我看了很多,发现我们可以通过以下函数直接使用JavaScript来实现它。
tableObject.insertRow(index)
index
是一个整数,指定要插入的行的位置(从0开始)。也可以使用-1的值;这导致新行将被插入到最后一个位置。
此参数在Firefox和Opera中是必需的,但在Internet Explorer Chrome和Safari中是可选的。
如果省略此参数,insertRow()
会在Internet Explorer的最后一个位置以及Chrome和Safari中的第一个位置插入一个新行。
它适用于HTML表的每个可接受的结构。
以下示例将在last中插入一行(-1用作索引):
<html>
<head>
<script type="text/javascript">
function displayResult()
{
document.getElementById("myTable").insertRow(-1).innerHTML = '<td>1</td><td>2</td>';
}
</script>
</head>
<body>
<table id="myTable" border="1">
<tr>
<td>cell 1</td>
<td>cell 2</td>
</tr>
<tr>
<td>cell 3</td>
<td>cell 4</td>
</tr>
</table>
<br />
<button type="button" onclick="displayResult()">Insert new row</button>
</body>
</html>
我希望它有所帮助。
答案 5 :(得分:34)
我推荐
$('#myTable > tbody:first').append('<tr>...</tr><tr>...</tr>');
而不是
$('#myTable > tbody:last').append('<tr>...</tr><tr>...</tr>');
first
和last
关键字适用于要启动但未关闭的第一个或最后一个标记。因此,如果您不希望更改嵌套表,而是添加到整个表中,则嵌套表会更好。至少,这是我发现的。
<table id=myTable>
<tbody id=first>
<tr><td>
<table id=myNestedTable>
<tbody id=last>
</tbody>
</table>
</td></tr>
</tbody>
</table>
答案 6 :(得分:31)
在我看来,最快捷的方式是
//Try to get tbody first with jquery children. works faster!
var tbody = $('#myTable').children('tbody');
//Then if no tbody just select your table
var table = tbody.length ? tbody : $('#myTable');
//Add row
table.append('<tr><td>hello></td></tr>');
这是演示 Fiddle
另外,我可以推荐一个小函数来进行更多的html更改
//Compose template string
String.prototype.compose = (function (){
var re = /\{{(.+?)\}}/g;
return function (o){
return this.replace(re, function (_, k){
return typeof o[k] != 'undefined' ? o[k] : '';
});
}
}());
如果您使用我的字符串编辑器,您可以这样做
var tbody = $('#myTable').children('tbody');
var table = tbody.length ? tbody : $('#myTable');
var row = '<tr>'+
'<td>{{id}}</td>'+
'<td>{{name}}</td>'+
'<td>{{phone}}</td>'+
'</tr>';
//Add row
table.append(row.compose({
'id': 3,
'name': 'Lee',
'phone': '123 456 789'
}));
这是演示 的 Fiddle 强>
答案 7 :(得分:23)
这可以使用jQuery的“last()”函数轻松完成。
$("#tableId").last().append("<tr><td>New row</td></tr>");
答案 8 :(得分:17)
当表格中没有任何行时,我正在使用这种方式,而且每一行都非常复杂。
的style.css:
...
#templateRow {
display:none;
}
...
xxx.html
...
<tr id="templateRow"> ... </tr>
...
$("#templateRow").clone().removeAttr("id").appendTo( $("#templateRow").parent() );
...
答案 9 :(得分:14)
对于此处发布的最佳解决方案,如果最后一行有嵌套表,则新行将添加到嵌套表而不是主表。一个快速的解决方案(考虑带有/不带tbody的表和带有嵌套表的表):
function add_new_row(table, rowcontent) {
if ($(table).length > 0) {
if ($(table + ' > tbody').length == 0) $(table).append('<tbody />');
($(table + ' > tr').length > 0) ? $(table).children('tbody:last').children('tr:last').append(rowcontent): $(table).children('tbody:last').append(rowcontent);
}
}
用法示例:
add_new_row('#myTable','<tr><td>my new row</td></tr>');
答案 10 :(得分:13)
我遇到了一些相关问题,尝试在点击的行后插入一个表格行。一切都很好,除了.after()调用不适用于最后一行。
$('#traffic tbody').find('tr.trafficBody).filter(':nth-child(' + (column + 1) + ')').after(insertedhtml);
我找到了一个非常不整洁的解决方案:
按如下方式创建表(每行的id):
<tr id="row1"> ... </tr>
<tr id="row2"> ... </tr>
<tr id="row3"> ... </tr>
等等......
然后:
$('#traffic tbody').find('tr.trafficBody' + idx).after(html);
答案 11 :(得分:13)
我这样解决了。
使用jquery
$('#tab').append($('<tr>')
.append($('<td>').append("text1"))
.append($('<td>').append("text2"))
.append($('<td>').append("text3"))
.append($('<td>').append("text4"))
)
$('#tab').append($('<tr>')
.append($('<td>').append("text1"))
.append($('<td>').append("text2"))
.append($('<td>').append("text3"))
.append($('<td>').append("text4"))
)
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<table id="tab">
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Age</th>
<th>City</th>
</tr>
<tr>
<td>Jill</td>
<td>Smith</td>
<td>50</td>
<td>New York</td>
</tr>
</table>
答案 12 :(得分:11)
您可以使用这个出色的jQuery add table row功能。它适用于具有<tbody>
但不具有// One table
addTableRow($('#myTable'));
// add table row to number of tables
addTableRow($('.myTables'));
的表。此外,它还考虑了您上一个表格行的colspan。
以下是一个示例用法:
{{1}}
答案 13 :(得分:10)
我的解决方案:
//Adds a new table row
$.fn.addNewRow = function (rowId) {
$(this).find('tbody').append('<tr id="' + rowId + '"> </tr>');
};
<强>用法:强>
$('#Table').addNewRow(id1);
答案 14 :(得分:10)
// Create a row and append to table
var row = $('<tr />', {})
.appendTo("#table_id");
// Add columns to the row. <td> properties can be given in the JSON
$('<td />', {
'text': 'column1'
}).appendTo(row);
$('<td />', {
'text': 'column2',
'style': 'min-width:100px;'
}).appendTo(row);
答案 15 :(得分:9)
Neil's answer是迄今为止最好的一个。然而,事情变得非常混乱。我的建议是使用变量来存储元素并将它们附加到DOM层次结构中。
<强> HTML 强>
<table id="tableID">
<tbody>
</tbody>
</table>
<强> JAVASCRIPT 强>
// Reference to the table body
var body = $("#tableID").find('tbody');
// Create a new row element
var row = $('<tr>');
// Create a new column element
var column = $('<td>');
// Create a new image element
var image = $('<img>');
image.attr('src', 'img.png');
image.text('Image cell');
// Append the image to the column element
column.append(image);
// Append the column to the row element
row.append(column);
// Append the row to the table body
body.append(row);
答案 16 :(得分:8)
我发现这个AddRow plugin对于管理表行非常有用。但是,如果你只需要添加一个新行,Luke的solution将是最合适的。
答案 17 :(得分:8)
document.getElementById("myTable").insertRow(-1).innerHTML = '<tr>...</tr><tr>...</tr>';
使用javascript函数编写
create function dbo.zipSearch(@zip varchar(12), @mile int)
returns table
as
begin
declare @ns float = @mile * 0.00569;
declare @ew float = @mile * 0.01629;
declare @ltt float, @lng float;
Select @ltt = latitude, @lng = longitude From ZipCode Where ZIP = @zip;
Select ZIP From zipcode Where latitude >= @ltt - @ns and latitude <= @ltt + @ns and longitude >= @lng - @ew and longitude <= @lng + @ew;
return
end
答案 18 :(得分:7)
这是我的解决方案
$('#myTable').append('<tr><td>'+data+'</td><td>'+other data+'</td>...</tr>');
答案 19 :(得分:7)
我猜我已经完成了我的项目,现在是:
<强> HTML 强>
<div class="container">
<div class = "row">
<div class = "span9">
<div class = "well">
<%= form_for (@replication) do |f| %>
<table>
<tr>
<td>
<%= f.label :SR_NO %>
</td>
<td>
<%= f.text_field :sr_no , :id => "txt_RegionName" %>
</td>
</tr>
<tr>
<td>
<%= f.label :Particular %>
</td>
<td>
<%= f.text_area :particular , :id => "txt_Region" %>
</td>
</tr>
<tr>
<td>
<%= f.label :Unit %>
</td>
<td>
<%= f.text_field :unit ,:id => "txt_Regio" %>
</td>
</tr>
<tr>
<td>
<%= f.label :Required_Quantity %>
</td>
<td>
<%= f.text_field :quantity ,:id => "txt_Regi" %>
</td>
</tr>
<tr>
<td></td>
<td>
<table>
<tr><td>
<input type="button" name="add" id="btn_AddToList" value="add" class="btn btn-primary" />
</td><td><input type="button" name="Done" id="btn_AddToList1" value="Done" class="btn btn-success" />
</td></tr>
</table>
</td>
</tr>
</table>
<% end %>
<table id="lst_Regions" style="width: 500px;" border= "2" class="table table-striped table-bordered table-condensed">
<tr>
<td>SR_NO</td>
<td>Item Name</td>
<td>Particular</td>
<td>Cost</td>
</tr>
</table>
<input type="button" id= "submit" value="Submit Repication" class="btn btn-success" />
</div>
</div>
</div>
</div>
<强> JS 强>
$(document).ready(function() {
$('#submit').prop('disabled', true);
$('#btn_AddToList').click(function () {
$('#submit').prop('disabled', true);
var val = $('#txt_RegionName').val();
var val2 = $('#txt_Region').val();
var val3 = $('#txt_Regio').val();
var val4 = $('#txt_Regi').val();
$('#lst_Regions').append('<tr><td>' + val + '</td>' + '<td>' + val2 + '</td>' + '<td>' + val3 + '</td>' + '<td>' + val4 + '</td></tr>');
$('#txt_RegionName').val('').focus();
$('#txt_Region').val('');
$('#txt_Regio').val('');
$('#txt_Regi').val('');
$('#btn_AddToList1').click(function () {
$('#submit').prop('disabled', false).addclass('btn btn-warning');
});
});
});
答案 20 :(得分:7)
<tr id="tablerow"></tr>
$('#tablerow').append('<tr>...</tr><tr>...</tr>');
答案 21 :(得分:7)
这是一些hacketi hack代码。我想在HTML页面中维护一个行模板。表行0 ... n在请求时呈现,此示例具有一个硬编码行和一个简化模板行。模板表是隐藏的,行标记必须位于有效表中,否则浏览器可能会从DOM树中删除它。添加行使用计数器+ 1标识符,并在数据属性中维护当前值。它保证每一行都有唯一的URL参数。
我已经在Internet Explorer 8,Internet Explorer 9,Firefox,Chrome,Opera,Nokia Lumia 800,Nokia C7(带Symbian 3),Android游戏和Firefox测试版浏览器上运行测试。
<table id="properties">
<tbody>
<tr>
<th>Name</th>
<th>Value</th>
<th> </th>
</tr>
<tr>
<td nowrap>key1</td>
<td><input type="text" name="property_key1" value="value1" size="70"/></td>
<td class="data_item_options">
<a class="buttonicon" href="javascript:deleteRow()" title="Delete row" onClick="deleteRow(this); return false;"></a>
</td>
</tr>
</tbody>
</table>
<table id="properties_rowtemplate" style="display:none" data-counter="0">
<tr>
<td><input type="text" name="newproperty_name_\${counter}" value="" size="35"/></td>
<td><input type="text" name="newproperty_value_\${counter}" value="" size="70"/></td>
<td><a class="buttonicon" href="javascript:deleteRow()" title="Delete row" onClick="deleteRow(this); return false;"></a></td>
</tr>
</table>
<a class="action" href="javascript:addRow()" onclick="addRow('properties'); return false" title="Add new row">Add row</a><br/>
<br/>
- - - -
// add row to html table, read html from row template
function addRow(sTableId) {
// find destination and template tables, find first <tr>
// in template. Wrap inner html around <tr> tags.
// Keep track of counter to give unique field names.
var table = $("#"+sTableId);
var template = $("#"+sTableId+"_rowtemplate");
var htmlCode = "<tr>"+template.find("tr:first").html()+"</tr>";
var id = parseInt(template.data("counter"),10)+1;
template.data("counter", id);
htmlCode = htmlCode.replace(/\${counter}/g, id);
table.find("tbody:last").append(htmlCode);
}
// delete <TR> row, childElem is any element inside row
function deleteRow(childElem) {
var row = $(childElem).closest("tr"); // find <tr> parent
row.remove();
}
PS:我给jQuery团队提供所有学分;他们应得的一切。没有jQuery的JavaScript编程 - 我甚至不想考虑那个噩梦。
答案 22 :(得分:6)
要在主题上添加一个好的示例,如果您需要在特定位置添加行,这里有一个可行的解决方案。
在第5行之后添加额外的行,如果少于5行,则在表的末尾添加。
var ninja_row = $('#banner_holder').find('tr');
if( $('#my_table tbody tr').length > 5){
$('#my_table tbody tr').filter(':nth-child(5)').after(ninja_row);
}else{
$('#my_table tr:last').after(ninja_row);
}
我把内容放在桌子下面的一个准备好的(隐藏的)容器中。如果你(或设计师)必须改变它,则不需要编辑JS。
<table id="banner_holder" style="display:none;">
<tr>
<td colspan="3">
<div class="wide-banner"></div>
</td>
</tr>
</table>
答案 23 :(得分:6)
<table id=myTable>
<tr><td></td></tr>
<style="height=0px;" tfoot></tfoot>
</table>
您可以缓存页脚变量并减少对DOM的访问(注意:使用假行而不是页脚可能会更好)。
var footer = $("#mytable tfoot")
footer.before("<tr><td></td></tr>")
答案 24 :(得分:6)
因为我也有办法在最后或任何特定的地方添加行,所以我想我也应该分享这个:
首先找出长度或行:
var r=$("#content_table").length;
然后使用下面的代码添加你的行:
$("#table_id").eq(r-1).after(row_html);
答案 25 :(得分:6)
如果你有另一个变量,你可以在<td>
标签中访问,就像尝试一样。
这样我希望它会有所帮助
var table = $('#yourTableId');
var text = 'My Data in td';
var image = 'your/image.jpg';
var tr = (
'<tr>' +
'<td>'+ text +'</td>'+
'<td>'+ text +'</td>'+
'<td>'+
'<img src="' + image + '" alt="yourImage">'+
'</td>'+
'</tr>'
);
$('#yourTableId').append(tr);
答案 26 :(得分:5)
如果您使用的是Datatable JQuery插件,可以试试。
oTable = $('#tblStateFeesSetup').dataTable({
"bScrollCollapse": true,
"bJQueryUI": true,
...
...
//Custom Initializations.
});
//Data Row Template of the table.
var dataRowTemplate = {};
dataRowTemplate.InvoiceID = '';
dataRowTemplate.InvoiceDate = '';
dataRowTemplate.IsOverRide = false;
dataRowTemplate.AmountOfInvoice = '';
dataRowTemplate.DateReceived = '';
dataRowTemplate.AmountReceived = '';
dataRowTemplate.CheckNumber = '';
//Add dataRow to the table.
oTable.fnAddData(dataRowTemplate);
参考数据表fnAddData Datatables API
答案 27 :(得分:5)
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
会向表格的第一个 TBODY
添加新行,而不依赖于任何THEAD
或TFOOT
。
(我没有找到来自哪个版本的jQuery .append()
此信息存在的信息。)
您可以在以下示例中尝试:
<table class="t"> <!-- table with THEAD, TBODY and TFOOT -->
<thead>
<tr><th>h1</th><th>h2</th></tr>
</thead>
<tbody>
<tr><td>1</td><td>2</td></tr>
</tbody>
<tfoot>
<tr><th>f1</th><th>f2</th></tr>
</tfoot>
</table><br>
<table class="t"> <!-- table with two TBODYs -->
<thead>
<tr><th>h1</th><th>h2</th></tr>
</thead>
<tbody>
<tr><td>1</td><td>2</td></tr>
</tbody>
<tbody>
<tr><td>3</td><td>4</td></tr>
</tbody>
<tfoot>
<tr><th>f1</th><th>f2</th></tr>
</tfoot>
</table><br>
<table class="t"> <!-- table without TBODY -->
<thead>
<tr><th>h1</th><th>h2</th></tr>
</thead>
</table><br>
<table class="t"> <!-- table with TR not in TBODY -->
<tr><td>1</td><td>2</td></tr>
</table>
<br>
<table class="t">
</table>
<script>
$('.t').append('<tr><td>a</td><td>a</td></tr>');
</script>
在a b
之后插入1 2
行,而不是在第二个示例中插入3 4
。如果表是空的,jQuery会为新行创建TBODY
。
答案 28 :(得分:5)
以一种简单的方式:
$('#yourTableId').append('<tr><td>your data1</td><td>your data2</td><td>your data3</td></tr>');
答案 29 :(得分:3)
如果您想在row
第一个孩子之前添加<tr>
。
$("#myTable > tbody").prepend("<tr><td>my data</td><td>more data</td></tr>");
如果您想在row
最后一个孩子后添加<tr>
。
$("#myTable > tbody").append("<tr><td>my data</td><td>more data</td></tr>");
答案 30 :(得分:1)
使用JQuery添加Tabe行:
如果要在表的行子项的最后一个孩子之后添加行,
$('#myTable tr:last').after('<tr>...</tr><tr>...</tr>');
如果您要添加行表的行子项的第一个,则可以尝试
$('#myTable tr').after('<tr>...</tr><tr>...</tr>');
答案 31 :(得分:1)
尝试一下:非常简单的方法
$('<tr><td>3</td></tr><tr><td>4</td></tr>').appendTo("#myTable tbody");
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<table id="myTable">
<tbody>
<tr><td>1</td></tr>
<tr><td>2</td></tr>
</tbody>
</table>
答案 32 :(得分:1)
上面的答案非常有帮助,但是当学生参考此链接以从表单添加数据时,他们通常需要样本。
我想提供一个示例,从中获取输入,并使用.after()
使用字符串interpolation
将tr插入表中。
function add(){
let studentname = $("input[name='studentname']").val();
let studentmark = $("input[name='studentmark']").val();
$('#student tr:last').after(`<tr><td>${studentname}</td><td>${studentmark}</td></tr>`);
}
function add(){
let studentname = $("input[name='studentname']").val();
let studentmark = $("input[name='studentmark']").val();
$('#student tr:last').after(`<tr><td>${studentname}</td><td>${studentmark}</td></tr>`);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<!DOCTYPE html>
<html>
<head>
<style>
table {
font-family: arial, sans-serif;
border-collapse: collapse;
width: 100%;
}
td, th {
border: 1px solid #dddddd;
text-align: left;
padding: 8px;
}
tr:nth-child(even) {
background-color: #dddddd;
}
</style>
</head>
<body>
<form>
<input type='text' name='studentname' />
<input type='text' name='studentmark' />
<input type='button' onclick="add()" value="Add new" />
</form>
<table id='student'>
<thead>
<th>Name</th>
<th>Mark</th>
</thead>
</table>
</body>
</html>
答案 33 :(得分:1)
您的情况下,纯JS很短
myTable.firstChild.innerHTML += '<tr><td>my data</td><td>more data</td></tr>'
function add() {
myTable.firstChild.innerHTML+=`<tr><td>date</td><td>${+new Date}</td></tr>`
}
td {border: 1px solid black;}
<button onclick="add()">Add</button><br>
<table id="myTable"><tbody></tbody> </table>
(如果我们删除<tbody>
和firstChild
也会起作用,但是用<tbody>
包装每一行)
答案 34 :(得分:1)
我尝试了获得最高评价的产品,但是它对我没有用,但是下面的产品效果很好。
$('#mytable tr').last().after('<tr><td></td></tr>');
哪怕有糖味也能起作用。
答案 35 :(得分:0)
也可以这样做:
$("#myTable > tbody").html($("#myTable > tbody").html()+"<tr><td>my data</td><td>more data</td></tr>")
答案 36 :(得分:0)
提示:通过html table
在innerHTML or .html()
中插入行在某些浏览器(类似于IE9
)中无效,而使用.append("<tr></tr>")
则无效任何浏览器中的好建议。 最佳和最快方式是使用pure javascript
代码。
要将此方法与jQuery
结合使用,请仅添加类似于jQuery
的新插件:
$.fn.addRow=function(index/*-1: add to end or any desired index*/, cellsCount/*optional*/){
if(this[0].tagName.toLowerCase()!="table") return null;
var i=0, c, r = this[0].insertRow((index<0||index>this[0].rows.length)?this[0].rows.length:index);
for(;i<cellsCount||0;i++) c = r.insertCell(); //you can use c for set its content or etc
return $(r);
};
现在在整个项目中使用它,如下所示:
var addedRow = $("#myTable").addRow(-1/*add to end*/, 2);
答案 37 :(得分:0)
要在当前行的最后添加新行,您可以这样使用
$('#yourtableid tr:last').after('<tr>...</tr><tr>...</tr>');
您可以如上所述追加多行。您也可以像这样添加内部数据
$('#yourtableid tr:last').after('<tr><td>your data</td></tr>');
以另一种方式可以做到这一点
let table = document.getElementById("tableId");
let row = table.insertRow(1); // pass position where you want to add a new row
//then add cells as you want with index
let cell0 = row.insertCell(0);
let cell1 = row.insertCell(1);
let cell2 = row.insertCell(2);
let cell3 = row.insertCell(3);
//add value to added td cell
cell0.innerHTML = "your td content here";
cell1.innerHTML = "your td content here";
cell2.innerHTML = "your td content here";
cell3.innerHTML = "your td content here";
答案 38 :(得分:0)
在这里,您可以单击按钮,然后将获得输出。当您点击添加行按钮时,又添加了一行。
我希望这会很有帮助。
<html>
<head>
<script src=
"https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js">
</script>
<style>
table {
margin: 25px 0;
width: 200px;
}
table th, table td {
padding: 10px;
text-align: center;
}
table, th, td {
border: 1px solid;
}
</style>
</head>
<body>
<b>Add table row in jQuery</b>
<p>
Click on the button below to
add a row to the table
</p>
<button class="add-row">
Add row
</button>
<table>
<thead>
<tr>
<th>Rows</th>
</tr>
</thead>
<tbody>
<tr>
<td>This is row 0</td>
</tr>
</tbody>
</table>
<!-- Script to add table row -->
<script>
let rowno = 1;
$(document).ready(function () {
$(".add-row").click(function () {
rows = "<tr><td>This is row "
+ rowno + "</td></tr>";
tableBody = $("table tbody");
tableBody.append(rows);
rowno++;
});
});
</script>
</body>
</html>
答案 39 :(得分:0)
)达里尔:
您可以使用 appendTo 方法将其附加到 tbody 中,如下所示:
$(() => {
$("<tr><td>my data</td><td>more data</td></tr>").appendTo("tbody");
});
您可能想要使用最新的 JQuery 和 ECMAScript。然后,您可以使用后端语言将数据添加到表中。您也可以将其包装在一个变量中,如下所示:
$(() => {
var t_data = $('<tr><td>my data</td><td>more data</td></tr>');
t_data.appendTo('tbody');
});