Add table row in jQuery
在jquery中,向表中添加一行作为最后一行的最佳方法是什么?
这可以接受吗?
1 | $('#myTable').append('<tr><td>my data</td><td>more data</td></tr>'); |
您可以向这样的表中添加的内容(如输入、选择、行数)是否有限制?
- Thxs Ash。我也在学习jquery,发现很难找到最好的方法,尤其是简单的方法。它们是2个问题的原因是因为我发了一个问题,然后一个小时后我意识到我应该把另一个问题放进去,而不认为我应该先改变。
- 因为这个:google.com/search?Q=jquery+add+table+row
- 仅供参考-避免使用多个附录(极大地降低性能),而应建立字符串或使用更快的javascript连接。
- 参见:stackoverflow.com/a/50365764/7186739
- 为了防止行太复杂,我要做的是用所需的结构隐藏第一行,克隆并修改文本,然后在第一行后插入,这样,如果从Ajax响应中提取数据,将创建表,请记住在循环外克隆它,然后使用它修改循环内的内容。$("maintable tbody").append(row);row是修改后的克隆副本:)
你建议的方法并不能保证给你想要的结果-如果你有一个
1 2 3 4 5 6 | <table id="myTable"> <tbody> <tr>...</tr> <tr>...</tr> </tbody> </table> |
你最终会得到以下结果:
1 2 3 4 5 6 7 | <table id="myTable"> <tbody> <tr>...</tr> <tr>...</tr> </tbody> <tr>...</tr> </table> |
因此,我建议采用这种方法:
1 | $('#myTable tr:last').after('<tr>...</tr><tr>...</tr>'); |
只要是有效的HTML,就可以在
更新:在最近关于此问题的活动之后重新访问此答案。眼睑松弛可以很好地说明dom中总是有一个
Darkon_u建议附加到
综合考虑,我不确定是否有一个单一的一行解决方案可以解释每一个可能的场景。您需要确保jquery代码与您的标记相匹配。
我认为最安全的解决方案可能是确保您的
1 | $('#myTable > tbody:last-child').append('<tr>...</tr><tr>...</tr>'); |
- 如果表中没有行,此操作是否有效?
- @拉玛,不会的。需要更好的解决方案。
- DOM中总是有一个tbody。
- 为什么不在tbody上放置一个ID来停止myTable>tbody选择的需要?
- @加雷斯,你可以这么做。但是,当您没有在标记中指定tbody时,这种方法仍然有效(因为它仍然存在于dom中)。因此它有点可重用。
- 但是空的tbody不能验证您的HTML
- $('myTable>tbody:last').append版本似乎颠倒了表行的顺序。
- 对原本不错的解决方案的一个微小改进是优化选择器。您可以使用:
$('#myTable').find('tbody:last') 而不是$('#myTable > tbody:last') 来提高速度。 - 注:如果存在,第一个解决方案可以将行添加到
tfoot 中,而第二个解决方案则不会。 - @Matthijswsels不一定是-t脚应该在tBody之前。后来把它放在HTML4中是无效的,HTML5允许你这样做,但它仍然不理想。尽管现在大多数人可能会使用HTML5(不像我第一次写答案的时候),但这绝对值得标记。
- @我不知道。下次我做桌子的时候,我会记住的。
- "眼睑松弛是一个很好的评价,在DOM中总是会有一个tbody"——我只是在没有tbody的情况下尝试了这个方法,但是它不起作用——它只在有tbody的情况下起作用。
- 认为最好的(不是为了速度,还有优化的空间)是:var tbl=$("mytable");if(tbl.find("tbody:last").length)tbl=tbl.find("tbody:last");tbl.append("
… … "); - @Lukebennett没有办法让作者指定HTML5,浏览器也不一定注意到doctype中的版本,因此,根据他们使用的浏览器(以及你无法控制的浏览器),一些幸运的访问者是否获得HTML5的行为几乎是运气不好。;-)当然,随着时间的推移,浏览器将使用HTML5,但它还是一个移动的目标…
- 找这种东西已经有一段时间了。谢谢你^。^真傻,有时候javascript真是变幻莫测。
- 对于此处的格式设置,抱歉:/在循环之前添加此$('myTable:Not(:has("tbody"))).append("
");/*add if not there/var tbod=$('.myTableBody');/Dont search for this every time use a var*//////then use this in your loop.tbod.append('.. .. ''); - @Brainslugs83是对的-我必须声明一个空的
tbody ,当桌子是空的时候它才能正常工作。- 我需要在我的新项目中使用它,我意识到这个答案并没有得到我想要的结果,而且我的表中定义了一个tbody。我可以这样做:
$('#myTable').find('tbody:last tr:last').after('
...</tr>');。 - 更新:我认为不需要你只需添加这个代码就可以正常工作。$("myTable tbody").append("
my data more data "); - 您可以在内部(td)使用
- 同时也要了解
。是的,这是一个非常古老的答案,阅读其他答案以获得更新的笔记/版本资料。- 还要注意,不能使用此方法连接到数组中位置的引用中。但是,您可以在
append() 函数之外定义它们,并引用变量。jquery有一个内置的功能,可以动态地操作DOM元素。
您可以像这样向表中添加任何内容:
1
2
3
4
5
6
7
8
9$("#tableID").find('tbody')
.append($('<tr>')
.append($('<td>')
.append($('<img>')
.attr('src', 'img.png')
.text('Image cell')
)
)
);jquery中的
$(' 是一个标签对象,它可以有几个可以设置和获取的') attr 属性,以及text 表示标签之间的文本: 。text 这是一个非常奇怪的缩进,但是您更容易看到这个示例中发生了什么。
- 对于那些尝试这个的人,请仔细注意括号的位置。正确的筑巢至关重要。
- 结束标签呢?不需要吗?
- 既然散列符号引用的是ID而不是类名,那么$("TableClassName")不应该是$("TableID")吗?
- @sammiwei您必须添加它,就像在最后一个结束括号的第二个结束括号后添加第一个td一样。
- 我讨厌这样奇怪的链子。维护充满此类内容的代码是一场噩梦。
- 与单个append()相比,运行多个append()的性能使得这样做效率低下。在大多数情况下,您最好先构建整个HTML字符串,然后在一张照片中附加它。这里有一个JSPerf测试来比较jspef.com/single-vs-multiple-jquery-append/4(警告:它实际上足以破坏一些浏览器)
- 这是一个聪明的答案,但是如果我们没有任何"tBody"标签会发生什么?
- @我希望我能先看一下你的评论…现在为了找回电脑,我把窗户扔了
- 如果没有tbody,它就找不到它(至少在chrome中),如果有多个tbody(允许),它会在它找到的每个tbody上附加一行--根据接受的答案,也许你应该这样做。find("tbody:last")--同样--当tbody不存在时,你应该有一个回退场景。
- @senfo添加子元素将自动创建这些子元素。
- 如果有嵌套表,最好使用.children()而不是.find()。
- $("tableid").find('tbody').append($('
image cell '); 所以,自从@luke bennett回答这个问题后,情况就发生了变化。这是一个更新。
jquery自1.4版(?)自动检测您试图插入的元素(使用
append() 、prepend() 、before() 或after() 方法中的任何一种)是否为,并将其插入表中的第一个 ,或者如果不存在则将其包装为新的 。 所以,是的,您的示例代码是可以接受的,并且可以与jquery 1.4+一起使用。;)
1$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');- 注意这个假设。如果附加的标记以或
开头,jquery将不会检测到它是一个并将其附加到 而不是 。我刚刚在一个MVC视图生成的标记中遇到了这个问题,这个视图的开头有一行多余的代码。
- @米克,谢谢你的提醒!我想
yourString.trim() 可以补救这个问题。- 当然,但你必须考虑一下。如果你知道有一个,最好养成附加到
的习惯。- jquery 3.1仍然要求指定tbody。在这里查看:jsfiddle.net/umaj5zz9/2
- 这会使我的页面刷新。我怎么能阻止呢?
- 如果要在多行中正确格式化HTML,并且使用ES6,请使用`而不是其他引号。请参阅stackoverflow.com/questions/805107
如果你有一个
和一个呢? 例如:
1
2
3
4
5
6
7
8<table>
<tbody>
<tr><td>Foo</td></tr>
</tbody>
<tfoot>
<tr><td>footer information</td></tr>
</tfoot>
</table>然后它会在页脚中插入新行,而不是在正文中。
因此,最好的解决方案是包含一个
标签,并使用.append ,而不是.after 。1$("#myTable > tbody").append("<tr><td>row content</td></tr>");- 您的tfoot实现不正确。它应该出现在tbody之前,而不是后面-参见w3.org/tr/html4/struct/tables.html h-11.2.3。因此,我的解决方案仍然有效,除非你选择打破标准(在这种情况下,你可以期待其他事情也会出错)。我的解决方案也适用于你是否有一个tbody,而你的建议将失败,如果一个tbody不存在。
- 尽管
中有任何错误,但这是一个更好的解决方案。如果没有 ,可以对本身使用相同的技术。而"接受的答案"则需要进行额外的检查,以查看是否存在现有的行。(我知道操作系统没有规定这个要求,但这并不重要——这篇文章在谷歌搜索中排名第一,最好的答案不是顶部。)
- 这是一个比找到更好的解决方案。在多次迭代中,这种技术似乎总是有效的。作为添加的fyi,可以使用.prepend将行添加到表的开头,而.append将行放置在表的结尾。
- 这是不正确的,它会将行附加到tbody中的每一行
- @你能告诉我怎么做吗?它针对的是tbody,而不是任何子元素。
- @查德对不起,我错了,我在试验,发现我的桌子结构不正确。但是该解决方案也可以在没有
tbody 的情况下工作。`"myTable").append("row");即使它同时具有thead和tfoot。 - @garg10may-如果您自己不在标记中包含tbody,浏览器将隐式地向dom添加tbody。
我知道你要求一个jquery方法。我看了很多,发现我们可以用更好的方法来完成它,而不是通过下面的函数直接使用javascript。
1tableObject.insertRow(index)index 是一个整数,指定要插入的行的位置(从0开始)。也可以使用-1的值;这将导致新行插入最后一个位置。此参数在Firefox和Opera中是必需的,但在Internet Explorer、Chrome和Safari中是可选的。
如果省略此参数,
insertRow() 将在Internet Explorer的最后一个位置和Chrome和Safari的第一个位置插入新行。它适用于HTML表的每个可接受结构。
下面的示例将在最后插入一行(-1用作索引):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25<html>
<head>
<script type="text/javascript">
function displayResult()
{
document.getElementById("myTable").insertRow(-1).innerHTML = '<td>1</td><td>2</td>';
}
</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>希望有帮助。
- 这个方法的问题(正如我刚刚发现的)是,如果您有一个页脚,它将在页脚后添加-1作为索引。
我推荐
1$('#myTable > tbody:first').append('<tr>...</tr><tr>...</tr>');而不是
1$('#myTable > tbody:last').append('<tr>...</tr><tr>...</tr>');first 和last 关键字在要启动的第一个或最后一个标记上工作,而不是关闭。因此,如果您不希望更改嵌套表,而是将其添加到整个表中,那么这对嵌套表的作用会更好。至少,这是我发现的。1
2
3
4
5
6
7
8
9
10<table id=myTable>
<tbody id=first>
<tr><td>
<table id=myNestedTable>
<tbody id=last>
</tbody>
</table>
</td></tr>
</tbody>
</table>在我看来,最快、最清晰的方法是
1
2
3
4
5
6
7
8//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更改
1
2
3
4
5
6
7
8
9//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] : '';
});
}
}());如果你用我的弦乐作曲家,你可以这样做
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15var 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()"函数轻松完成。
1$("#tableId").last().append("<tr><td>New row</td></tr>");- 好主意,但我认为您应该将选择器更改为tableid tr,因为现在您可以让表添加表下的行。
当表中没有任何行,并且每一行都非常复杂时,我使用这种方法。
CSS:
1
2
3
4
5...
#templateRow {
display:none;
}
...XXX.HTML
1
2
3
4
5
6
7...
<tr id="templateRow"> ... </tr>
...
$("#templateRow").clone().removeAttr("id").appendTo( $("#templateRow").parent() );
...- 谢谢您。这是一个非常优雅的解决方案。我喜欢它如何将模板保持在网格中。它使代码变得更简单,更容易阅读和维护。再次感谢。
为了得到这里发布的最佳解决方案,如果最后一行有一个嵌套表,那么新行将被添加到嵌套表中,而不是主表中。快速解决方案(考虑带/不带tbody的表和带嵌套表的表):
1
2
3
4
5
6function 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);
}
}使用实例:
1add_new_row('#myTable','<tr><td>my new row</td></tr>');我遇到了一些相关的问题,试图在单击的行后插入一个表行。除了最后一行的.after()调用不起作用外,其他一切都很好。
1$('#traffic tbody').find('tr.trafficBody).filter(':nth-child(' + (column + 1) + ')').after(insertedhtml);最后我得到了一个非常不整洁的解决方案:
创建表如下(每行ID):
1
2
3<tr id="row1"> ... </tr>
<tr id="row2"> ... </tr>
<tr id="row3"> ... </tr>等。。。
然后:
1$('#traffic tbody').find('tr.trafficBody' + idx).after(html);- Missing HTML is
so on.. - 我认为这应该是一个新问题,而不是对现有问题的回答…
我是这样解决的。
使用jQuery
1
2
3
4
5
6$('#tab').append($('<tr>')
.append($('<td>').append("text1"))
.append($('<td>').append("text2"))
.append($('<td>').append("text3"))
.append($('<td>').append("text4"))
)片断
1
2
3
4
5
6$('#tab').append($('<tr>')
.append($('<td>').append("text1"))
.append($('<td>').append("text2"))
.append($('<td>').append("text3"))
.append($('<td>').append("text4"))
)1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js">
<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>- 我现在可以成功地在新行中添加动态数据,但使用此方法后,我的自定义筛选器将不起作用。您对此有任何解决方案吗?汉克你
- 我认为您需要调用某种更新函数。不举例说明。
- 这是最好的答案…谢谢您
1
2
3
4
5
6
7
8
9
10
11
12
13// 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);- 虽然这可能是一个答案,但对后来的访客来说并不是很有用…请在你的答案周围加上一些解释。
我的解决方案:
1
2
3
4//Adds a new table row
$.fn.addNewRow = function (rowId) {
$(this).find('tbody').append('<tr id="' + rowId + '"> </tr>');
};用途:
1$('#Table').addNewRow(id1);- 那么,如果表中没有
tbody ,该怎么办??表示在
元素中可以直接有行,即使没有任何头。
- 我强烈建议您将标记设为
以使其符合HTML 5标准,如果不是,则可以始终执行$(this)。append('');that just appends a row in the table. 的表,而不具有- 我认为,如果您要使它成为一个函数,您可能会为新行返回一个jquery对象,所以它是可链接的。
您可以使用这个伟大的jquery添加表行功能。它适用于具有
的表。它还考虑了最后一行的列跨度。 下面是一个示例用法:
1
2
3
4// One table
addTableRow($('#myTable'));
// add table row to number of tables
addTableRow($('.myTables'));- 我看不出这是多么有用。它所做的只是向表中添加一个空表行。通常,如果不总是这样,您希望添加一个包含一些数据的新表行。
- 但这通常是你想要的。此函数允许您向任何表中添加空行,无论您有多少列和行跨度,从而使其成为通用函数。您可以从那里继续,例如使用$('.tbl tr:last td')。关键是要有普遍的功能!!!!
- 如果函数还向新行中添加数据,则下次在下一个项目中将无法使用它。有什么意义?!但我认为,你不需要分享它…
- 如果您提议的函数不是通用包的一部分,请在这里输入完整的函数代码。谢谢您。
尼尔的回答是迄今为止最好的。但是事情会很快变得混乱。我的建议是使用变量来存储元素并将它们附加到DOM层次结构中。
HTML
1
2
3
4<table id="tableID">
<tbody>
</tbody>
</table>JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20// 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);我发现这个addrow插件对于管理表行非常有用。不过,如果您只需要添加一行,卢克的解决方案将是最合适的。
1
2
3
4
5
6
7<table id="myTable">
<tbody>
<tr>...</tr>
<tr>...</tr>
</tbody>
<tr>...</tr>
</table>使用javascript函数编写
1document.getElementById("myTable").insertRow(-1).innerHTML = '<tr>...</tr><tr>...</tr>';这是一些黑客代码。我想在HTML页面中维护一个行模板。表行0…n在请求时呈现,这个示例有一个硬编码行和一个简化的模板行。模板表是隐藏的,行标记必须在有效的表中,否则浏览器可能会将其从DOM树中删除。添加行使用counter+1标识符,当前值在数据属性中维护。它保证每一行获得唯一的URL参数。
我在Internet Explorer 8、Internet Explorer 9、Firefox、Chrome、Opera、Nokia Lumia 800、Nokia C7(带Symbian 3)、Android Stock和Firefox Beta浏览器上运行过测试。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47<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">
</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></td>
</tr>
</table>
Add row<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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57<%= 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" />JS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18$(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');
});
});
});
1
2
3<tr id="tablerow"></tr>
$('#tablerow').append('<tr>...</tr><tr>...</tr>');这是我的解决方案
1$('#myTable').append('<tr><td>'+data+'</td><td>'+other data+'</td>...</tr>');
1
2
3
4<table id=myTable>
<tr><td></td></tr>
<style="height=0px;" tfoot></tfoot>
</table>您可以缓存footer变量并减少对dom的访问(注意:也许最好使用伪行而不是footer)。
1
2var footer = $("#mytable tfoot")
footer.before("<tr><td></td></tr>")为了在这个主题上添加一个好的例子,如果需要在特定位置添加一行,这里提供了一个有效的解决方案。
在第5行之后添加额外的行,如果少于5行,则添加到表的末尾。
1
2
3
4
5
6
7var 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。
1
2
3
4
5
6
7<table id="banner_holder" style="display:none;">
<tr>
<td colspan="3">
</td>
</tr>
</table>如果你有另一个变量,你可以在
标签中访问,就像这样。 我希望这样会有帮助
1
2
3
4
5
6
7
8
9
10
11
12
13
14var 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);因为我也有办法在最后或任何特定的地方添加行,所以我想我也应该分享这一点:
首先找出长度或行数:
1var r=$("#content_table").length;然后使用下面的代码添加行:
1$("#table_id").eq(r-1).after(row_html);
1$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');将在表的第一个
TBODY 中添加新行,而不依赖于存在的任何THEAD 或TFOOT 。(我没有找到jquery.append() 的哪个版本的信息,该行为存在。)您可以在以下示例中进行尝试:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42<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>
<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>
<table class="t"> <!-- table without TBODY -->
<thead>
<tr><th>h1</th><th>h2</th></tr>
</thead>
</table>
<table class="t"> <!-- table with TR not in TBODY -->
<tr><td>1</td><td>2</td></tr>
</table>
<table class="t">
</table>
$('.t').append('<tr><td>a</td><td>a</td></tr>');其中,在第二个示例中,
a b 行插入到1 2 之后,而不是在3 4 之后。如果表为空,jquery将为新行创建TBODY 。如果您使用的是datatable jquery插件,则可以尝试。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20oTable = $('#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
简单来说:
1$('#yourTableId').append('<tr><td>your data1</td><td>your data2</td><td>your data3</td></tr>');- 请您详细说明一下您的答案,并对您提供的解决方案做一点描述,好吗?
如果要在
第一个孩子之前添加 row 。1$("#myTable > tbody").prepend("<tr><td>my data</td><td>more data</td></tr>");如果你想把
row 加在最后一个孩子后面。 1$("#myTable > tbody").append("<tr><td>my data</td><td>more data</td></tr>");试试这个:非常简单的方法
1$('<tr><td>3</td></tr><tr><td>4</td></tr>').appendTo("#myTable tbody");1
2
3
4
5
6
7<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.1.1/jquery.min.js">
<table id="myTable">
<tbody>
<tr><td>1</td></tr>
<tr><td>2</td></tr>
</tbody>
</table>使用jquery添加tabe行:
如果要在表的最后一个子行之后添加行,可以尝试此操作
1$('#myTable tr:last').after('<tr>...</tr><tr>...</tr>');如果要添加表的行子级的第一行,可以尝试此操作
1$('#myTable tr').after('<tr>...</tr><tr>...</tr>');也可以这样做:
1$("#myTable > tbody").html($("#myTable > tbody").html()+"<tr><td>my data</td><td>more data</td></tr>")- 这看起来相当复杂,浏览器/JS处理起来可能更慢,因为它需要解析更多的HTML。
提示:通过
innerHTML or .html() 在html table 中插入行在某些浏览器(类似IE9 中)中无效,在任何浏览器中使用.append(" ")都不是很好的建议。最好和最快的方法是使用
pure javascript 代码。对于与
jQuery 结合的方式,只需添加与jQuery 类似的新插件:1
2
3
4
5
6$.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);
};现在整个项目中使用它类似于:
1var addedRow = $("#myTable").addRow(-1/*add to end*/, 2);
- 关于javascript:在表格中添加新行
- 关于javascript:如何动态添加表行
- 关于javascript:使用jQuery在表中追加一个新行
- 使用jquery将行添加到表中
- 关于jquery:当我使用Javascript单击按钮时,如何在表中添加新行
- 在javascript中创建多行字符串
- 关于javascript:Jquery在某个索引处将新行插入表中
- 关于html:如何使用jQuery将行追加到表中?
- 创建表行的克隆并在JavaScript中附加到表
- 关于javascript:jquery有"exists"函数吗?
- 关于javascript:如何删除选择框的所有选项,然后添加一个选项并使用jQuery选择它?
- 关于javascript:使用jQuery删除表行的最佳方法是什么?
- 关于javascript:如何检查jquery中是否隐藏了元素?
- 关于javascript:使用jquery设置复选框的"选中"?
- 关于HTML:如何检查jquery中是否选中复选框?
- 关于javascript:在HTML5本地存储中存储对象
- 关于javascript:如何决定何时使用node.js?
- 在JavaScript控制台中包含jQuery
- 关于JavaScript的:"如果我有一个想法在angularjs"jQuery的背景?
Copyright © 码农家园 联系:[email protected] - 我强烈建议您将标记设为
- @米克,谢谢你的提醒!我想
- 注意这个假设。如果附加的标记以或