javascript - 如何将 JSON 数据转换为制表符表

标签 javascript json tabulator

我有一些需要在制表符表中使用的 JSON 数据。

这里是制表器的简单示例。 http://tabulator.info/docs/4.2/quickstart我必须转换 JSON,但正在努力寻找一个动态解决方案,比如说,如果我有一个带有键值的额外键,它仍然可以与制表符表一起使用。这是我的 JSON 数据。

{
  "Aspen_Premium": [
    279245, 
    945317, 
    118388
  ], 
  "Brokerage_Upfront": [
    825831, 
    141166, 
    507242
  ], 
  "Brokers": [
    "JLT", 
    "Willis", 
    "BMS"
  ]
}

我需要将它放在这样的 JavaScript 文件中。

var tabledata = [
    {id: 1, Aspen_Premium: 279245, Brokerage_Upfront: 825831, Brokers: "JTL"},    
    {id: 2, Brokerage_Upfront: 945317, Brokerage_Upfront: 141166, Brokers: "Willis"},
    {id: 3, Brokers: 118388, Brokerage_Upfront: 507242, Brokers: "BMS"},    
]


var table = new Tabulator("#broker-table", {
    height:205, 
    data:tabledata, 
    layout:"fitColumns", 
    columns:[ 
        {title:"Aspen_Premium", field:"Aspen_Premium", width:150},
        {title:"Brokerage_Upfront", field:"Brokerage_Upfront"},
        {title:"Brokers", field:"Brokers"},

    ],
    rowClick:function(e, row){ //trigger an alert message when the row is clicked
        alert("Row " + row.getData().id + " Clicked!!!!");
    },
});

我的 HTML 很简单:

<!DOCTYPE html>
<html lang="en">
<head>
<title>Check 1</title>

<link href="https://unpkg.com/tabulator-tables@4.2.2/dist/css/tabulator.min.css" rel="stylesheet">
<script type="text/javascript" src="https://unpkg.com/tabulator-tables@4.2.2/dist/js/tabulator.min.js"></script>

<script   src="http://code.jquery.com/jquery-3.3.1.min.js"   integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8="   crossorigin="anonymous"></script>
<script   src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"   integrity="sha256-VazP97ZCwtekAsvgPBSUwPFKdrwD3unUfSGVYrahUqU="   crossorigin="anonymous"></script>

</head>
<body>


<div id="broker-table"></div>

<script type="text/javascript" src="{{url_for('static',filename='js/checking1.js')}}"></script>
</body>
</html>

我正在使用 Python Flask。因此,javascript 文件 check1.js 的链接具有 src="{{url_for('static', filename='js/checking1.js')}}">

任何帮助将不胜感激,因为我已经为此奋斗了几个小时,试图将 JSON 转换为上述硬编码版本。 我尝试使用 for 循环,但不断遇到问题。

我如何从 http://127.0.0.1:5000/broker_data 获取 JSON 数据的示例

$.get("/broker_data").then(function(data){

    var columns = Object.keys(data);

    var tabledata = [];

    for(var i = 0; i < data[columns[0]].length; i++){


        tabledata.push({"id": i+1, "Aspen": data[columns[0]][i]})
    } console.log(tabledata);
});

上面的内容并不理想,因为我必须对“Aspen”键名称进行硬编码。

最佳答案

回答有关转换 JSON 数据的部分,这可能会有所帮助。如果

var data = {
    'Aspen_Premium':[279245,945317,118388],
    'Brokerage_Upfront':[825831,141166,507242],
    'Brokers':['JLT','Willis','BMS']
};

将其转换为所需格式的一种方法:

[
    {id: 1, Aspen_Premium: 279245, Brokerage_Upfront: 825831, Brokers: "JTL"},    
    {id: 2, Brokerage_Upfront: 945317, Brokerage_Upfront: 141166, Brokers: "Willis"},
    {id: 3, Brokers: 118388, Brokerage_Upfront: 507242, Brokers: "BMS"},    
]

将是以下 JavaScript:

//This gets the length of the array in the first element
var numItems = data[Object.keys(data)[0]].length;

var desiredJSON = [];
for( var itemIndex = 0; itemIndex < numItems; itemIndex++){
  var doc = {};
  doc.id = itemIndex;
  for( dataElemIndex in data) {
    doc[dataElemIndex] = data[dataElemIndex][itemIndex];
  }
  desiredJSON.push(doc);
}

在此循环之后,desiredJSON 包含您尝试获取的文档数组。 此代码假设 data 中的所有元素都具有相同长度的数组。

关于javascript - 如何将 JSON 数据转换为制表符表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55027145/

相关文章:

javascript - getData 不反射(reflect)对 Tabulator 表所做的更改

javascript - 如何在点击时使用 jQuery 添加标题子菜单?

javascript - JSON - 传递表单输入值作为 json 字符串出错

Json 字符串中的 C# Json 字符串

cors - 制表符ajax请求和CORS

javascript - 制表符将 JSON 上传到服务器

javascript - 如何将 html 元素放在 fabric.js 元素上

javascript - Offset ().top - 距顶部 50%?

javascript - 在某处调用数组的(未定义的)其余部分

javascript - 未捕获的类型错误 : Cannot use 'in' operator to search for '123' in