我的自定义X轴值未显示在flot js中。

绘制折线图的代码如下:

var length = 0;
var length1 = 0;
var dataXY = [];
var data = [];
var dataX = [];
length = allVenues.length;
for (var i = 0; i < length; i++) {
     length1 = allVenues[i].length;
     for (var j = 0; j < length1; j++) {
         dataX.push([j, returnDate(allVenues[i][j].date)]);
         dataXY.push([returnTimestamp(allVenues[i][j].date), allVenues[i][j].price, "<b>X</b> : " + returnDate(allVenues[i][j].date) + " | " + " <b>Y</b>: " + allVenues[i][j].price]);
     }
}
var result = {'label': 'Demo Graph', 'data': dataXY};
data = [result];

var options = {
    lines: {
      show: true
    },
    points: {
       show: true
    },
    xaxis: {
       ticks: dataX
    },
    grid: {
       hoverable: true,
       clickable: true
    },
    tooltip: {
        show: true,
        content: "%s | X: %x | Y: %y"
   }
};
function returnTimestamp(val) {
  var dateTime = new Date(val);
  return moment(dateTime).unix();
}

function returnDate(val) {
   var dateTime = new Date(val);
   return moment(dateTime).format("YYYY-MM-DD hh:mm:ss A");
}

$.plot("#placeholder", data, options);


dataXY数组值为:

{"label":"Demo Graph","data":[[1455776629,12],[1455801889,30],[1455962948,45]]}


dataX数组的值为:

[[0, "2016-02-18 11:53:49 AM"], [1, "2016-02-18 06:54:49 PM"], [2, "2016-02-20 03:39:08 PM"]]


现在,我想将此“ dataX”数组设置为图表上的X轴值(刻度)。
该值在带有X轴的折线图的每个点下方显示。
这里是allVenues Json Array的dataX和dataXY。

除了X轴数据外,我的图形运行正常。您可以在下图中看到。

javascript - 在Flot中设置自定义X轴值-LMLPHP

最佳答案

刻度的dataX数组必须与真实数据数组具有相同的x值(时间戳):

[[1455776629, "2016-02-18 11:53:49 AM"], [1455801889, "2016-02-18 06:54:49 PM"], [1455962948, "2016-02-20 03:39:08 PM"]]


PS:我还建议在日期和时间之间在标签中放置一个换行符(<br>)。

10-06 04:25