Konvertieren Sie JSON-Daten in eine HTML-Tabelle [geschlossen]

112

Gibt es eine jQuery- oder Javascript-Bibliothek, die eine dynamische Tabelle mit json-Daten generiert? Ich möchte die Spalten nicht definieren, die Bibliothek sollte die Schlüssel im JSON-Hash lesen und Spalten generieren.

Natürlich kann ich selbst die JSON-Daten durchlaufen und die HTML-Tabelle generieren. Ich möchte nur wissen, ob es eine solche Bibliothek gibt, die ich einfach wiederverwenden kann.

Manish Mulani
quelle
Ich denke, trirand.com/blog ist das, wonach Sie suchen. Es nimmt JSON und konvertiert es in ein Raster.
Gokul NK
1
Danke für die Antworten. Aber um meine Anforderungen zu erfüllen, habe ich eine für mich geschrieben. jsfiddle.net/manishmmulani/7MRx6
Manish Mulani
2
Sie können dieses einfache Projekt auch auf Github verwenden: Json-To-HTML-Tabelle
Afshin Mehrabani
Verwenden Sie im Jahr 2020 einfach github.com/arters/Convert-json-data-to-a-html-template
kkasp

Antworten:

136

Vielen Dank für Ihre Antworten. Ich habe selbst einen geschrieben. Bitte beachten Sie, dass dies jQuery verwendet.

Code-Auszug:

var myList = [
  { "name": "abc", "age": 50 },
  { "age": "25", "hobby": "swimming" },
  { "name": "xyz", "hobby": "programming" }
];

// Builds the HTML Table out of myList.
function buildHtmlTable(selector) {
  var columns = addAllColumnHeaders(myList, selector);

  for (var i = 0; i < myList.length; i++) {
    var row$ = $('<tr/>');
    for (var colIndex = 0; colIndex < columns.length; colIndex++) {
      var cellValue = myList[i][columns[colIndex]];
      if (cellValue == null) cellValue = "";
      row$.append($('<td/>').html(cellValue));
    }
    $(selector).append(row$);
  }
}

// Adds a header row to the table and returns the set of columns.
// Need to do union of keys from all records as some records may not contain
// all records.
function addAllColumnHeaders(myList, selector) {
  var columnSet = [];
  var headerTr$ = $('<tr/>');

  for (var i = 0; i < myList.length; i++) {
    var rowHash = myList[i];
    for (var key in rowHash) {
      if ($.inArray(key, columnSet) == -1) {
        columnSet.push(key);
        headerTr$.append($('<th/>').html(key));
      }
    }
  }
  $(selector).append(headerTr$);

  return columnSet;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<body onLoad="buildHtmlTable('#excelDataTable')">
  <table id="excelDataTable" border="1">
  </table>
</body>

Manish Mulani
quelle
Hi @ Manish-mulani das hat bei mir nicht funktioniert, könntest du nochmal nachschauen
Nish
1
@ Nish Haben Sie jsfiddle.net/manishmmulani/7MRx6
Manish Mulani
1
Hallo, ich habe versucht, die Daten von einer URL zu erhalten, aber es scheint nicht zu funktionieren
3
Hallo. Dieser arbeitet für mich. Ich habe jedoch eine Frage. Warum gibt es keine Öffnung trund tdTags? Vielen Dank.
Cyval
function addAllColumnHeaders(myList)- ist falsch. sollte sein function addAllColumnHeaders(myList,selector). Übrigens funktioniert das perfekt !!
Shirker
60

Ich habe Ihren Code in vanilla-js umgeschrieben und dabei DOM-Methoden verwendet, um eine HTML-Injektion zu verhindern.

Demo

var _table_ = document.createElement('table'),
  _tr_ = document.createElement('tr'),
  _th_ = document.createElement('th'),
  _td_ = document.createElement('td');

// Builds the HTML Table out of myList json data from Ivy restful service.
function buildHtmlTable(arr) {
  var table = _table_.cloneNode(false),
    columns = addAllColumnHeaders(arr, table);
  for (var i = 0, maxi = arr.length; i < maxi; ++i) {
    var tr = _tr_.cloneNode(false);
    for (var j = 0, maxj = columns.length; j < maxj; ++j) {
      var td = _td_.cloneNode(false);
      cellValue = arr[i][columns[j]];
      td.appendChild(document.createTextNode(arr[i][columns[j]] || ''));
      tr.appendChild(td);
    }
    table.appendChild(tr);
  }
  return table;
}

// Adds a header row to the table and returns the set of columns.
// Need to do union of keys from all records as some records may not contain
// all records
function addAllColumnHeaders(arr, table) {
  var columnSet = [],
    tr = _tr_.cloneNode(false);
  for (var i = 0, l = arr.length; i < l; i++) {
    for (var key in arr[i]) {
      if (arr[i].hasOwnProperty(key) && columnSet.indexOf(key) === -1) {
        columnSet.push(key);
        var th = _th_.cloneNode(false);
        th.appendChild(document.createTextNode(key));
        tr.appendChild(th);
      }
    }
  }
  table.appendChild(tr);
  return columnSet;
}

document.body.appendChild(buildHtmlTable([{
    "name": "abc",
    "age": 50
  },
  {
    "age": "25",
    "hobby": "swimming"
  },
  {
    "name": "xyz",
    "hobby": "programming"
  }
]));

Oriol
quelle
1
Ist es möglich, diese Arbeit mit einem verschachtelten JSON-Objekt zu machen?
Janac Meena
@ JanacMeena Ich denke, Sie würden dafür n-dimensionale Tabellen benötigen.
Oriol
Das ist richtig. Tabellen in Tabellen. Außerdem habe ich zoombare Baumkarten entdeckt, die verschachtelten Json ermöglichen
Janac Meena
Dieselbe
1
@Shai benutze JSON.parse (yourVariable) und sende es an buldHTMLTable
xSx
13

Sie können das einfache jQuery jPut-Plugin verwenden

http://plugins.jquery.com/jput/

<script>
$(document).ready(function(){

var json = [{"name": "name1","email":"[email protected]"},{"name": "name2","link":"[email protected]"}];
//while running this code the template will be appended in your div with json data
$("#tbody").jPut({
    jsonData:json,
    //ajax_url:"youfile.json",  if you want to call from a json file
    name:"tbody_template",
});

});
</script>   

<table jput="t_template">
 <tbody jput="tbody_template">
     <tr>
         <td>{{name}}</td>
         <td>{{email}}</td>
     </tr>
 </tbody>
</table>

<table>
 <tbody id="tbody">
 </tbody>
</table>
shabeer
quelle
13

Schauen Sie sich das JSON2HTML- Plugin http://json2html.com/ für jQuery an. Hier können Sie eine Transformation angeben, die Ihr JSON-Objekt in eine HTML-Vorlage konvertiert. Verwenden Sie den Builder unter http://json2html.com/ , um das JSON-Transformationsobjekt für eine beliebige HTML-Vorlage abzurufen. In Ihrem Fall wäre es eine Tabelle mit einer Zeile mit der folgenden Transformation.

Beispiel:

var transform = {"tag":"table", "children":[
    {"tag":"tbody","children":[
        {"tag":"tr","children":[
            {"tag":"td","html":"${name}"},
            {"tag":"td","html":"${age}"}
        ]}
    ]}
]};

var data = [
    {'name':'Bob','age':40},
    {'name':'Frank','age':15},
    {'name':'Bill','age':65},
    {'name':'Robert','age':24}
];

$('#target_div').html(json2html.transform(data,transform));
Tschad
quelle
Ich dachte, ich würde den Link hier zu json2html.com aktualisieren
Chad Brown