javascript - 使用 JSON 数据绘制 Highchart 多系列折线图

标签 javascript json highcharts linechart

我尝试使用 JSON 数据绘制 JSON 数据。 JSFiddle 下面是我用 JavaScript 编写的 JSON 数据。

var JSON = [
{ name:"Maintenance",
  data:[[2017-06-26,1.5],
          [2017-07-03,5.2],
          [2017-07-10,1.65],
          [2017-07-17,2.5],
          [2017-07-24,1.5]
  ] 
},
{ name:"Others",
  data:[[2017-06-26,1.5],
          [2017-07-03,1.5],
          [2017-07-10,1.5],
          [2017-07-17,1.25],
          [2017-07-24,1.5]
  ] 
},
{ name:"Project",
  data:[[2017-06-26,6.5],
          [2017-07-03,6.1],
          [2017-07-10,6.7],
          [2017-07-17,7],
          [2017-07-24,6.5]
  ] 
},
{ name:"Training",
  data:[[2017-06-26,0],
          [2017-07-03,0.75],
          [2017-07-10,1.9],
          [2017-07-17,0.5],
          [2017-07-24,1]
  ] 
},
{ name:"Day-Off",
  data:[[2017-06-26,0],
          [2017-07-03,0],
          [2017-07-10,0],
          [2017-07-17,0],
          [2017-07-24,1]
  ] 
}]

但是,图表看起来很奇怪。对于每个系列,都有一条连接起点和终点的附加线。另外,x轴的值不是我想要的日期。

//Draw chart
Highcharts.chart('trend_bl', {

title: {
    text: 'Trend by Business Lines'
},
yAxis: {
    title: {
        text: ' Resource Allocation'
    }
},
legend: {
    layout: 'vertical',
    align: 'right',
    verticalAlign: 'middle'
},

series : JSON,
});

谁能告诉我为什么会这样?另外,我还想知道Highchart中折线图和饼图的正确JSON数据结构。

最佳答案

您在 JSON 中的日期应该是字符串。此日期应转换为毫秒。

var JSON = [{
  name: "Maintenance",
  data: [
    ['2017-06-26', 1.5],
    ['2017-07-03', 5.2],
    ['2017-07-10', 1.65],
    ['2017-07-17', 2.5],
    ['2017-07-24', 1.5]
  ]
}, {
  name: "Others",
  data: [
    ['2017-06-26', 1.5],
    ['2017-07-03', 1.5],
    ['2017-07-10', 1.5],
    ['2017-07-17', 1.25],
    ['2017-07-24', 1.5]
  ]
}, {
  name: "Project",
  data: [
    ['2017-06-26', 6.5],
    ['2017-07-03', 6.1],
    ['2017-07-10', 6.7],
    ['2017-07-17', 7],
    ['2017-07-24', 6.5]
  ]
}, {
  name: "Training",
  data: [
    ['2017-06-26', 0],
    ['2017-07-03', 0.75],
    ['2017-07-10', 1.9],
    ['2017-07-17', 0.5],
    ['2017-07-24', 1]
  ]
}, {
  name: "Day-Off",
  data: [
    ['2017-06-26', 0],
    ['2017-07-03', 0],
    ['2017-07-10', 0],
    ['2017-07-17', 0],
    ['2017-07-24', 1]
  ]
}];
//updating jsons date to millisecond
Object.keys(JSON).map(function(key, index) {
  JSON[key].data.map(function(value, keys, index) {
    JSON[key].data[keys][0]=new Date(value[0]).getTime()
  })
});
//console.log(JSON)

Fiddle Demo

关于javascript - 使用 JSON 数据绘制 Highchart 多系列折线图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45293530/

相关文章:

javascript - 如果存在另一个请求,如何停止ajax请求

javascript - .toFixed() 会导致计算错误吗?

c# - 文本框自动计算

javascript - Highchart 十字准线不接触 x 轴

javascript - Highcharts.js yAxis 值格式设置问题

javascript - Material 表可编辑 : Making all rows editable at once

php - 在 PHP 中迭代和分组对象数组

javascript - 如何在javascript中从JSON对象获取没有键的值

c# - Json.Net 中的强类型 Object[]

java - highcharts 导出服务器无法开箱即用(Java)