jQuery在表中添加最后一行作为最后一行的最佳方法是什么?
这可以接受吗?
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
您可以向这样的表添加什么内容(例如输入,选择,行数)是否有限制?
jQuery在表中添加最后一行作为最后一行的最佳方法是什么?
这可以接受吗?
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
您可以向这样的表添加什么内容(例如输入,选择,行数)是否有限制?
Answers:
您建议的方法并不能保证能为您提供所需的结果- 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,就可以在方法中包括任何内容,包括上面示例中的多行。
更新:最近对此问题进行了活动之后,重新访问此答案。双眼失明很好地说明tbody
了DOM中总会有一个。这是正确的,但前提是至少有一行。如果没有行,tbody
除非您自己指定一个行,否则将没有行。
DaRKoN_ 建议追加到tbody
而不是在最后一个之后添加内容tr
。这解决了没有行的问题,但是仍然不是防弹的,因为理论上您可以有多个tbody
元素,并且行会添加到每个元素中。
权衡一切,我不确定是否有一个单一的解决方案可以解决每种可能的情况。您将需要确保jQuery代码符合您的标记。
我认为最安全的解决方案可能是确保您的标记中table
始终包含至少一个tbody
,即使它没有行。在此基础上,您可以使用以下代码,无论您拥有多少行(并且也考虑了多个tbody
元素),它们都将起作用:
$('#myTable > tbody:last-child').append('<tr>...</tr><tr>...</tr>');
$('#myTable').find('tbody:last')
代替来提高速度$('#myTable > tbody:last')
。
jQuery有一个内置的工具可以即时操作DOM元素。
您可以像这样将任何东西添加到表中:
$("#tableID").find('tbody')
.append($('<tr>')
.append($('<td>')
.append($('<img>')
.attr('src', 'img.png')
.text('Image cell')
)
)
);
$('<some-tag>')
jQuery中的东西是一个标签对象,它可以具有几个attr
可以设置和获取的属性,以及text
,它们代表标签之间的文本:<tag>text</tag>
。
这是一个非常奇怪的缩进,但是您可以更轻松地了解此示例中发生的情况。
因此,自@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>');
yourString.trim()
可以解决这个问题。
如果您有a <tbody>
和a <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>");
我知道您已要求使用jQuery方法。我看了很多东西,发现我们可以通过比下面的函数直接使用JavaScript更好的方式来做到这一点。
tableObject.insertRow(index)
index
是一个整数,指定要插入的行的位置(从0开始)。也可以使用值-1。结果是新行将被插入到最后一个位置。
在Firefox和Opera中,此参数是必需的,但在Internet Explorer,Chrome和Safari中,此参数是可选的。
如果省略此参数,则insertRow()
在Internet Explorer中的最后一个位置以及Chrome和Safari中的第一个位置插入一个新行。
它适用于HTML表格的每个可接受的结构。
以下示例将在最后插入一行(-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>
希望对您有所帮助。
我建议
$('#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>
我认为最快最明确的方法是
//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>');
这是演示 小提琴
我也可以推荐一个小的功能来进行更多的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'
}));
这是演示 小提琴
tbody
插件,可以使用多个插件
$("SELECTOR").last()
限制标签的收集
使用jQuery的“ last()”函数可以轻松完成此操作。
$("#tableId").last().append("<tr><td>New row</td></tr>");
对于此处发布的最佳解决方案,如果最后一行上有嵌套表,则将新行添加到嵌套表中,而不是主表中。快速解决方案(考虑带/不带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>');
我这样解决了。
使用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>
我遇到一些相关问题,试图在单击的行之后插入表格行。一切都很好,除了.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);
您可以使用此出色的jQuery添加表行功能。它适用于具有<tbody>
和不具有表的表。此外,它还考虑了最后一个表格行的colspan。
这是一个示例用法:
// One table
addTableRow($('#myTable'));
// add table row to number of tables
addTableRow($('.myTables'));
我的解决方案:
//Adds a new table row
$.fn.addNewRow = function (rowId) {
$(this).find('tbody').append('<tr id="' + rowId + '"> </tr>');
};
用法:
$('#Table').addNewRow(id1);
tbody
表中没有呢?意味着<table>
即使没有任何标题,也可以在元素内部直接存在行。
// 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);
尼尔的答案是迄今为止最好的答案。但是事情很快就会变得混乱。我的建议是使用变量存储元素,并将其附加到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);
<table id="myTable">
<tbody>
<tr>...</tr>
<tr>...</tr>
</tbody>
<tr>...</tr>
</table>
用javascript函数编写
document.getElementById("myTable").insertRow(-1).innerHTML = '<tr>...</tr><tr>...</tr>';
这是一些hacketi hack代码。我想在HTML页面中维护行模板。表行0 ... n在请求时呈现,并且此示例具有一个硬编码行和一个简化的模板行。模板表是隐藏的,并且行标记必须在有效表中,否则浏览器可能会将其从DOM树中删除。添加一行使用counter + 1标识符,并且当前值保留在data属性中。它保证每一行都获得唯一的URL参数。
我已经在Internet Explorer 8,Internet Explorer 9,Firefox,Chrome,Opera,诺基亚Lumia 800,诺基亚C7(与Symbian 3),Android股票和Firefox beta浏览器上运行过测试。
<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编程-我什至不想考虑那个噩梦。
我猜我已经在我的项目中完成过,这里是:
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');
});
});
});
如果您还有另一个变量,则可以<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);
要在该主题上添加一个很好的示例,如果您需要在特定位置添加一行,则这里是可行的解决方案。
多余的行将添加到第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>
<table id=myTable>
<tr><td></td></tr>
<style="height=0px;" tfoot></tfoot>
</table>
您可以缓存页脚变量并减少对DOM的访问(注意:使用假行代替页脚可能会更好)。
var footer = $("#mytable tfoot")
footer.before("<tr><td></td></tr>")
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
将添加一个新行到第一 TBODY
表中的,而不取决于任何THEAD
或TFOOT
存在。(我没有从.append()
存在此行为的jQuery版本中找到信息。)
您可以在以下示例中尝试:
<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
一个新行。
如果您使用的是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 数据表API
用简单的方法:
$('#yourTableId').append('<tr><td>your data1</td><td>your data2</td><td>your data3</td></tr>');