javascript - 带有 JSON 数据的 DataTable

标签 javascript jquery json datatables datatables-1.10

我正在尝试使用 DataTable 创建一个表,但很难让 DataTable 使用 JSON 对象加载。

function getData() {
var request = new XMLHttpRequest();
var json = "link-to-my-json-object";
// Get JSON file
request.onload = function() {
  if ( request.readyState === 4 && request.status === 200 ) {
    var JSONObject = JSON.parse(request.responseText);
    createTable(JSONObject);
  } else if(request.status == 400) { console.log("Error", request.status);}
};
request.open("GET", json, true);
request.send();
}

通过 XMLHttpRequest() 请求请求 JSON 文件。

JSON 对象的简短示例:

{
"meta": {
"version": 1,
"type": "test"
},
"reports": [
{
  "report-metadata": {
    "timestamp": 1528235303.721987,
    "from-ip": "0.0.0.0"
  }, 
//and so on...

当前仅尝试在 DataTable 表中显示 meta 部分:

function createTable(jsonData){ 
 $(document).ready(function(){
  $('#table').dataTable({
    data: jsonData,
    columns: [
      { data: 'meta.type' },
      { data: 'meta.version' }
    ]
  });
 });
}

index.html部分:

<table id="table" class="display" style="width:100%"></table>

运行时只得到表中没有可用数据,我显然遗漏了一些东西。

最佳答案

用于初始化数据表的“数据”属性需要一个列表(每个元素代表一行)。修改您的 ajax 响应,使每一行都是 jsonData 列表中的一个元素。我还在所有 JSON 选项周围添加了引号。

var jsonData = [
    { "meta": { "version": 1, "type": "test" } }
];

$('#table').DataTable({
    "data": jsonData,
    "columns": [
      { "data": "meta.type" },
      { "data": "meta.version" }
    ]
});

https://datatables.net/reference/option/data

由于您想通过 ajax 加载数据,因此您应该查看 DataTables API 中内置的 ajax 选项。 https://datatables.net/manual/ajax

关于javascript - 带有 JSON 数据的 DataTable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51023879/

相关文章:

javascript - 使用 javascript 订购随机表单选项

javascript - 循环保存到 MongoDB

jQuery:取消设置/删除函数事件的最佳实践?

javascript - Rails 表单通过 ajax post 提交,不调用成功或错误回调函数

Javascript/NodeJS 回调函数和循环

json - 将 JSON 元组解码为 Elm 元组

java - 将 JSON 字符串映射到 HashMap

javascript - fullcalendar:周 View 中每天所有事件的总持续时间

c# - Json.NET 在返回 json 序列化字符串时添加反斜杠

javascript - 根据部分匹配查找 div id 的值