最後の行としてテーブルに行を追加する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>');
このようなテーブルに追加できるもの(入力、選択、行数など)に制限はありますか?
回答:
あなたが提案するアプローチはあなたが探している結果をあなたに与えることを保証されていません- 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 には常にaが存在することになるといいコメントをしています。これは真実ですが、少なくとも1つの行がある場合に限ります。行がない場合は、tbody
自分で指定し限り。
DaRKoN_ はtbody
、最後にコンテンツを追加するのではなく、に追加することをお勧めしtr
ます。これは行がないという問題を回避しますが、理論的には複数にすることができるため、完全ではありませんtbody
要素を持ち、各行に行が追加されるため、完全ではありません。
すべてを比較検討しているのですが、考えられるすべてのシナリオを説明する単一の1行ソリューションがあるかどうかはわかりません。jQueryコードがマークアップと一致していることを確認する必要があります。
行がない場合でも、マークアップにtable
少なくとも1つ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がこの質問に答えたので、事は変わりました。これが更新です。
あなたは(のいずれかの使用して挿入しようとしている要素場合は、バージョン1.4(?)以来のjQueryを自動的に検出しappend()
、prepend()
、before()
、またはafter()
メソッド)がある<tr>
と、最初に挿入し、それを<tbody>
あなたのテーブルまたは新しいにそれをラップ<tbody>
1がない場合存在します。
だから、はい、あなたのサンプルコードは許容可能であり、jQuery 1.4+で正常に動作します。;)
$('#myTable').append('<tr><td>my data</td><td>more data</td></tr>');
yourString.trim()
これは改善できると思います。
とがあったらどう<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>");
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()
タグのコレクションを制限することを試みることができます
テーブルに行がない場合や、各行が非常に複雑な場合に、この方法を使用しています。
style.css:
...
#templateRow {
display:none;
}
...
xxx.html
...
<tr id="templateRow"> ... </tr>
...
$("#templateRow").clone().removeAttr("id").appendTo( $("#templateRow").parent() );
...
ここに掲載されている最善の解決策として、最後の行にネストされたテーブルがある場合、新しい行はメインテーブルではなくネストされたテーブルに追加されます。簡単な解決策(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 add table row関数を使用できます。それは持っているテーブルでうまく機能します<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>
ジャバスクリプト
// 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プラグインは、テーブルの行を管理するのに非常に便利です。ただし、新しい行を追加するだけの場合は、Lukeのソリューションが最適です。
これがハッケチハックコードです。HTMLページで行テンプレートを維持したいと思っていました。テーブルの行0 ... nはリクエスト時にレンダリングされ、この例にはハードコードされた1つの行と簡略化されたテンプレート行があります。テンプレートテーブルは非表示になっており、行タグは有効なテーブル内にある必要があります。そうしないと、ブラウザがそれをDOMツリーからドロップする可能性があります。行を追加すると、counter + 1識別子が使用され、現在の値はdata属性に保持されます。各行が一意の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プログラミング-その悪夢について考えたくありません。
私は自分のプロジェクトで私がやったと思います、ここにあります:
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');
});
});
});
これは私の解決策です
$('#myTable').append('<tr><td>'+data+'</td><td>'+other data+'</td>...</tr>');
別の変数がある場合は、<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
存在しないかは関係ありません。(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
新しい行を作成します。
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
簡単な方法で:
$('#yourTableId').append('<tr><td>your data1</td><td>your data2</td><td>your data3</td></tr>');
これを試してください:非常に簡単な方法
$('<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>