从包含JSON的PHP页面填充Tabulator表

时间:2019-04-22 16:27:48

标签: tabulator

我是编程和制表新手。我有一个显示我的JSON结果的PHP页面。我只想在另一个页面上的制表器表中查看此结果。

JSON结果的格式如下,它位于名为 proxystatus.php 的页面上。

{ "0": {
    "hostid": "10610",
    "proxy_hostid": "10609",
    "host": "PIDMPRX-DEV",
    "status": "0",
    "disable_until": "0",
    "error": "",
    "available": "1",
    "errors_from": "0",
    "lastaccess": "0",
    "ipmi_authtype": "-1",
    "ipmi_privilege": "2",
    "ipmi_username": "",
    "ipmi_password": "",
    "ipmi_disable_until": "0",
    "ipmi_available": "0",
    "snmp_disable_until": "0",
    "snmp_available": "1",
    "maintenanceid": "0",
    "maintenance_status": "0",
    "maintenance_type": "0",
    "maintenance_from": "0",
    "ipmi_errors_from": "0",
    "snmp_errors_from": "0",
    "ipmi_error": "",
    "snmp_error": "",
    "jmx_disable_until": "0",
    "jmx_available": "0",
    "jmx_errors_from": "0",
    "jmx_error": "",
    "name": "0955-PIDM-PRX",
    "flags": "0",
    "templateid": "0",
    "description": "0955\ \ Company Name",
    "tls_connect": "1",
    "tls_accept": "1",
    "tls_issuer": "",
    "tls_subject": "",
    "tls_psk_identity": "",
    "tls_psk": "",
    "proxy_address": "",
    "auto_compress": "1"
}}

我的制表器表代码如下,它位于名为 dash.php

的页面上
var table = new Tabulator("#proxyStatus", {
    height:"100%",
    layout:"fitColumns",
    placeholder:"Gathering Proxy Status...", 
        data:'<?=$proxyStatus?>',
        columns:[
            {title:"Status", field:"status", sorter:"string", width:200},
            {title:"Available", field:"available", sorter:"number", formatter:"progress"},
            {title:"Last Access", field:"lastaccess", sorter:"string"},
            {title:"Name", field:"name", formatter:"star", align:"center", width:100},
            {title:"Maintenance Status", field:"maintenance_status", sorter:"string", sortable:false},
            {title:"Maintenance Type", field:"maintenance_type", sorter:"date", align:"center"},
            {title:"Maintenance ID", field:"maintenanceid", align:"center", formatter:"tickCross", sorter:"boolean"},
        ],
    });

1 个答案:

答案 0 :(得分:0)

您应将所有列添加到columns数组中,或仅在构造函数中使用autoColumns:true,如here所述Jsfiddle是为了让您了解

const table = new Tabulator("#example-table", {
  height: 205, // set height of table (in CSS or here), this enables the Virtual DOM and improves render speed dramatically (can be any valid css height value)
  data: tabledata1, //assign data to table
  layout: "fitData", //fit columns to width of table (optional)
  autoColumns: true,

});