¿Existe una manera realmente fácil de tomar una matriz de objetos JSON y convertirla en una tabla HTML, excluyendo algunos campos? ¿O tendré que hacer esto manualmente?
javascript
jquery
json
ajax
html-table
Josh Stodola
fuente
fuente
Usar jQuery hará que esto sea más sencillo.
El siguiente código tomará una matriz de matrices y almacenará convertirlas en filas y celdas.
$.getJSON(url , function(data) { var tbl_body = ""; var odd_even = false; $.each(data, function() { var tbl_row = ""; $.each(this, function(k , v) { tbl_row += "<td>"+v+"</td>"; }); tbl_body += "<tr class=\""+( odd_even ? "odd" : "even")+"\">"+tbl_row+"</tr>"; odd_even = !odd_even; }); $("#target_table_id tbody").html(tbl_body); });
Puede agregar un cheque para las claves que desea excluir agregando algo como
var expected_keys = { key_1 : true, key_2 : true, key_3 : false, key_4 : true };
al comienzo de la función de devolución de llamada getJSON y agregando:
if ( ( k in expected_keys ) && expected_keys[k] ) { ... }
alrededor de la línea tbl_row + =.
Editar: estaba asignando una variable nula anteriormente
Editar: Versión basada en Timmmm 's libre de inyección de contribución.
$.getJSON(url , function(data) { var tbl_body = document.createElement("tbody"); var odd_even = false; $.each(data, function() { var tbl_row = tbl_body.insertRow(); tbl_row.className = odd_even ? "odd" : "even"; $.each(this, function(k , v) { var cell = tbl_row.insertCell(); cell.appendChild(document.createTextNode(v.toString())); }); odd_even = !odd_even; }); $("#target_table_id").append(tbl_body); //DOM table doesn't have .appendChild });
fuente
<tr>
alternar entre tener una clase de pares o impares?Cree una tabla HTML a partir de una matriz JSON de objetos extendiendo $ como se muestra a continuación
$.makeTable = function (mydata) { var table = $('<table border=1>'); var tblHeader = "<tr>"; for (var k in mydata[0]) tblHeader += "<th>" + k + "</th>"; tblHeader += "</tr>"; $(tblHeader).appendTo(table); $.each(mydata, function (index, value) { var TableRow = "<tr>"; $.each(value, function (key, val) { TableRow += "<td>" + val + "</td>"; }); TableRow += "</tr>"; $(table).append(TableRow); }); return ($(table)); };
y utilizar de la siguiente manera:
var mydata = eval(jdata); var table = $.makeTable(mydata); $(table).appendTo("#TableCont");
donde TableCont es un div
fuente
Forma HTML puro, no vulnerable como los demás AFAIK:
// Function to create a table as a child of el. // data must be an array of arrays (outer array is rows). function tableCreate(el, data) { var tbl = document.createElement("table"); tbl.style.width = "70%"; for (var i = 0; i < data.length; ++i) { var tr = tbl.insertRow(); for(var j = 0; j < data[i].length; ++j) { var td = tr.insertCell(); td.appendChild(document.createTextNode(data[i][j].toString())); } } el.appendChild(tbl); }
Uso de ejemplo:
$.post("/whatever", { somedata: "test" }, null, "json") .done(function(data) { rows = []; for (var i = 0; i < data.Results.length; ++i) { cells = []; cells.push(data.Results[i].A); cells.push(data.Results[i].B); rows.push(cells); } tableCreate($("#results")[0], rows); });
fuente
Conversión de una matriz de JavaScript 2D en una tabla HTML
Para convertir una matriz de JavaScript 2D en una tabla HTML, realmente necesita un poco de código:
function arrayToTable(tableData) { var table = $('<table></table>'); $(tableData).each(function (i, rowData) { var row = $('<tr></tr>'); $(rowData).each(function (j, cellData) { row.append($('<td>'+cellData+'</td>')); }); table.append(row); }); return table; } $('body').append(arrayToTable([ ["John","Slegers",34], ["Tom","Stevens",25], ["An","Davies",28], ["Miet","Hansen",42], ["Eli","Morris",18] ]));
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
Cargando un archivo JSON
Si desea cargar su matriz 2D desde un archivo JSON, también necesitará un poco de código Ajax:
$.ajax({ type: "GET", url: "data.json", dataType: 'json', success: function (data) { $('body').append(arrayToTable(data)); } });
fuente
Para objetos JSON muy avanzados en tablas HTML, puede probar My jQuery Solution que se basa en este hilo cerrado .
var myList=[{"name": "abc","age": 50},{"name": {"1": "piet","2": "jan","3": "klaas"},"age": "25","hobby": "watching tv"},{"name": "xyz","hobby": "programming","subtable": [{"a": "a","b": "b"},{"a": "a","b": "b"}]}]; // Builds the HTML Table out of myList json data from Ivy restful service. function buildHtmlTable() { addTable(myList, $("#excelDataTable")); } function addTable(list, appendObj) { var columns = addAllColumnHeaders(list, appendObj); for (var i = 0; i < list.length; i++) { var row$ = $('<tr/>'); for (var colIndex = 0; colIndex < columns.length; colIndex++) { var cellValue = list[i][columns[colIndex]]; if (cellValue == null) { cellValue = ""; } if (cellValue.constructor === Array) { $a = $('<td/>'); row$.append($a); addTable(cellValue, $a); } else if (cellValue.constructor === Object) { var array = $.map(cellValue, function (value, index) { return [value]; }); $a = $('<td/>'); row$.append($a); addObject(array, $a); } else { row$.append($('<td/>').html(cellValue)); } } appendObj.append(row$); } } function addObject(list, appendObj) { for (var i = 0; i < list.length; i++) { var row$ = $('<tr/>'); var cellValue = list[i]; if (cellValue == null) { cellValue = ""; } if (cellValue.constructor === Array) { $a = $('<td/>'); row$.append($a); addTable(cellValue, $a); } else if (cellValue.constructor === Object) { var array = $.map(cellValue, function (value, index) { return [value]; }); $a = $('<td/>'); row$.append($a); addObject(array, $a); } else { row$.append($('<td/>').html(cellValue)); } appendObj.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(list, appendObj) { var columnSet = []; var headerTr$ = $('<tr/>'); for (var i = 0; i < list.length; i++) { var rowHash = list[i]; for (var key in rowHash) { if ($.inArray(key, columnSet) == -1) { columnSet.push(key); headerTr$.append($('<th/>').html(key)); } } } appendObj.append(headerTr$); return columnSet; }
fuente
Puede usar un complemento jQuery que acepte datos JSON para llenar una tabla. jsonTable
fuente
Encontré un duplicado aquí: Convertir datos json en una tabla html
Bueno, existen muchos complementos, incluido uno comercial (¡¿Hacer esto como un proyecto comercial?! Un poco exagerado ... pero puede verificar aquí: https://github.com/alfajango/jquery-dynatable )
Este tiene más bifurcación: https://github.com/afshinm/Json-to-HTML-Table
//Example data, Object var objectArray = [{ "Total": "34", "Version": "1.0.4", "Office": "New York" }, { "Total": "67", "Version": "1.1.0", "Office": "Paris" }]; //Example data, Array var stringArray = ["New York", "Berlin", "Paris", "Marrakech", "Moscow"]; //Example data, nested Object. This data will create nested table also. var nestedTable = [{ key1: "val1", key2: "val2", key3: { tableId: "tblIdNested1", tableClassName: "clsNested", linkText: "Download", data: [{ subkey1: "subval1", subkey2: "subval2", subkey3: "subval3" }] } }];
Aplicar el código
//Only first parameter is required var jsonHtmlTable = ConvertJsonToTable(objectArray, 'jsonTable', null, 'Download');
O puede que también desee consultar estos complementos de jQuery: https://github.com/jongha/jquery-jsontotable
Creo que los complementos de jongha son más fáciles de usar
<div id="jsontotable" class="jsontotable"></div> var data = [[1, 2, 3], [1, 2, 3]]; $.jsontotable(data, { id: '#jsontotable', header: false });
fuente
Si acepta usar otra herramienta dependiente de jQuery , le recomendaría usar Tabulator . Entonces no necesitará escribir HTML o cualquier otro código generador de DOM, mientras mantiene una gran flexibilidad con respecto al formato y procesamiento de los datos de la tabla.
Para ver otro ejemplo de trabajo usando Node , puede ver el proyecto de demostración MMM-Tabulator .
fuente
Una forma sencilla de hacer esto es:
var data = [{ "Total": 34, "Version": "1.0.4", "Office": "New York" }, { "Total": 67, "Version": "1.1.0", "Office": "Paris" }]; drawTable(data); function drawTable(data) { // Get Table headers and print var head = $("<tr />") $("#DataTable").append(head); for (var j = 0; j < Object.keys(data[0]).length; j++) { head.append($("<th>" + Object.keys(data[0])[j] + "</th>")); } // Print the content of rows in DataTable for (var i = 0; i < data.length; i++) { drawRow(data[i]); } } function drawRow(rowData) { var row = $("<tr />") $("#DataTable").append(row); row.append($("<td>" + rowData["Total"] + "</td>")); row.append($("<td>" + rowData["Version"] + "</td>")); row.append($("<td>" + rowData["Office"] + "</td>")); }
table { border: 1px solid #666; width: 100%; text-align: center; } th { background: #f8f8f8; font-weight: bold; padding: 2px; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <table id="DataTable"></table>
fuente
con jquery puro:
window.jQuery.ajax({ type: "POST", url: ajaxUrl, contentType: 'application/json', success: function (data) { var odd_even = false; var response = JSON.parse(data); var head = "<thead class='thead-inverse'><tr>"; $.each(response[0], function (k, v) { head = head + "<th scope='row'>" + k.toString() + "</th>"; }) head = head + "</thead></tr>"; $(table).append(head);//append header var body="<tbody><tr>"; $.each(response, function () { body=body+"<tr>"; $.each(this, function (k, v) { body=body +"<td>"+v.toString()+"</td>"; }) body=body+"</tr>"; }) body=body +"</tbody>"; $(table).append(body);//append body }, error: function (xhr, ajaxOptions, thrownError) { alert(xhr.responsetext); } });
fuente
Puede hacer esto con bastante facilidad con Javascript + Jquery como se muestra a continuación. Si desea excluir alguna columna, simplemente escriba una declaración if dentro de los bucles for para omitir esas columnas. ¡Espero que esto ayude!
//Sample JSON 2D array var json = [{ "Total": "34", "Version": "1.0.4", "Office": "New York" }, { "Total": "67", "Version": "1.1.0", "Office": "Paris" }]; // Get Table headers and print for (var k = 0; k < Object.keys(json[0]).length; k++) { $('#table_head').append('<td>' + Object.keys(json[0])[k] + '</td>'); } // Get table body and print for (var i = 0; i < Object.keys(json).length; i++) { $('#table_content').append('<tr>'); for (var j = 0; j < Object.keys(json[0]).length; j++) { $('#table_content').append('<td>' + json[i][Object.keys(json[0])[j]] + '</td>'); } $('#table_content').append('</tr>'); }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <table> <thead> <tr id="table_head"> </tr> </thead> <tbody id="table_content"> </tbody> </table>
fuente
Se modificó un código de bits del código de @ Dr.sai. Espero que esto sea de utilidad.
(function ($) { /** * data - array of record * hidecolumns, array of fields to hide * usage : $("selector").generateTable(json, ['field1', 'field5']); */ 'use strict'; $.fn.generateTable = function (data, hidecolumns) { if ($.isArray(data) === false) { console.log('Invalid Data'); return; } var container = $(this), table = $('<table>'), tableHead = $('<thead>'), tableBody = $('<tbody>'), tblHeaderRow = $('<tr>'); $.each(data, function (index, value) { var tableRow = $('<tr>').addClass(index%2 === 0 ? 'even' : 'odd'); $.each(value, function (key, val) { if (index == 0 && $.inArray(key, hidecolumns) <= -1 ) { var theaddata = $('<th>').text(key); tblHeaderRow.append(theaddata); } if ($.inArray(key, hidecolumns) <= -1 ) { var tbodydata = $('<td>').text(val); tableRow.append(tbodydata); } }); $(tableBody).append(tableRow); }); $(tblHeaderRow).appendTo(tableHead); tableHead.appendTo(table); tableBody.appendTo(table); $(this).append(table); return this; }; })(jQuery);
Esperando que esto sea útil para ocultar algunas columnas también. Enlace al archivo
fuente
Vista pivotada de una sola fila con encabezados a la izquierda según la respuesta de @ Dr.sai anterior.
Inyección evitada por el método .text de jQuery
$.makeTable = function (mydata) { var table = $('<table>'); $.each(mydata, function (index, value) { // console.log('index '+index+' value '+value); $(table).append($('<tr>')); $(table).append($('<th>').text(index)); $(table).append($('<td>').text(value)); }); return ($(table)); };
fuente
Un camino aún más corto
$.makeTable = function (mydata) { if (mydata.length <= 0) return ""; return $('<table border=1>').append("<tr>" + $.map(mydata[0], function (val, key) { return "<th>" + key + "</th>"; }).join("\n") + "</tr>").append($.map(mydata, function (index, value) { return "<tr>" + $.map(index, function (val, key) { return "<td>" + val + "</td>"; }).join("\n") + "</tr>"; }).join("\n")); };
fuente