web-dev-qa-db-ja.com

データテーブルjqueryに複数の行を追加する方法

私は https://datatables.net/reference/api/rows.add%28%29 リンクを使用しましたが、データは_[object,object]_としてテーブルを示しています。オブジェクトを文字列に表示する方法。私はJSON.stringify(obj)を使用しましたが、これも機能しません。

[〜#〜] html [〜#〜]

_<table id="exampleTable">
 <thead>
  <tr>
   <th>Year</th>
   <th>Month</th>
   <th>Savings</th>
  </tr>
 </thead>
 <tbody>
   <tr>
    <td>2012</td>
    <td>January</td>
    <td>$100</td>
   </tr>
   <tr>
    <td>2012</td>
    <td>February</td>
    <td>$80</td>
   </tr>
 </table>
_

[〜#〜] js [〜#〜]

_$('#addRows').click(); 

var table3 = $('#exampleTable').DataTable(); 

$('#addRows').on( 'click', function () { 
    table3.row.add(
       [ { "Year": "Tiger Nixon", "Month": "System Architect", "Savings": "$3,120" },
         {"Year": "Tiger Nixon", "Month": "System Architect", "Savings": "$3,120" }]
    ).draw(); 
});
_
13
Krishna

これで2つのサンプルを作成しました [〜#〜] fiddle [〜#〜]

行追加でオブジェクトを使用する場合は、データテーブルの初期化で列を追加する必要があります。

[〜#〜] js [〜#〜]

var table3 = $('#exampleTable').DataTable({
    data:[{ "Year": "2012", "Month": "January", "Savings": "$100" },
      { "Year": "2012", "Month": "February", "Savings": "$80" }],
    columns:[{data: 'Year'},
        {data: "Month"},
        {data: "Savings"}]
}); 

しかし、これを実行したくない場合は、次の構文を行に追加して追加できます。

[〜#〜] js [〜#〜]

table4.rows.add(
   [[ "Tiger Nixon", "System Architect","$3,120" ],
     ["Tiger Nixon", "System Architect", "$3,120" ]]
).draw(); 

見てください フィドル より情報的です。

15
Baximilian

私もこの問題に遭遇しました-ドキュメントが不明確であることがわかりました。 https://datatables.net/reference/api/rows.add() の例は、動的に作成された独自のオブジェクトの配列を渡すと機能しません。

これを機能させるには、DataTableをインスタンス化するときに列の名前を指定する必要があります。

いずれにせよ、以下は有効な解決策です。

var DataTable = $('#tableName').DataTable({
  iDisplayLength: 15,   // number of rows to display
  columns: [
    { data: 'id' },
    { data: 'name' },
    { data: 'car' },
  ]
});

// assume this is a dynamically created array of objects
var persons = [
  {
    id: 1,
    name: 'John',
    car: 'Mercedes',
  }, 
  {
    id: 2,
    name: 'Dave',
    car: 'BMW',
  }, 
  {
    id: 3,
    name: 'Ken',
    car: 'Jeep',
  },  
];

DataTable.rows.add(persons).draw();
3
puiu

これを試す `

var data = [
  {id : 1, name : 'John'},
  {id : 2, name : 'Joe'},
  {id : 3, name : 'Mathan'},
  {id : 4, name : 'Mani'},
  {id : 4, name : 'Karthik'}
];

//データテーブルを初期化します

var DataTable = $('#tableName').DataTable({
 iDisplayLength: 15,  
 columns: [
 { data: 'id' },
 { data: 'name' },
 ]
});

DataTable.rows.add(data).draw();
1
Murali

私はforeachループのようにビューを返しています。それは複数の行を返します。今度はすべての機能がデータテーブルで機能するようにデータテーブルに追加します。

hTML形式で複数行の形式のみでデータを取得する場合にのみ機能します。

これは私のデータテーブルです

   $('#SurveyDetails').dataTable({
    "scrollY": "500px",
    "scrollX": true,
    "scrollCollapse": true,
    "paging": false,
    "jQueryUI": false,
    "searching": false,
    "autoWidth": false,      
 });

データテーブルのスクロールに30行を追加しています。

ajaxの成功時:

   success: function (data) {
            if (!$.trim(data) == '') {

                data = data.replace(/^\s*|\s*$/g, '');
                data = data.replace(/\\r\\n/gm, '');
                var expr = "</tr>\\s*<tr";
                var regEx = new RegExp(expr, "gm");
                var newRows = data.replace(regEx, "</tr><tr");
                $("#SurveyDetails").DataTable().rows.add($(newRows)).draw();
             }
0
Veer Jangid