NVD3 неправильно форматирует даты

Я пытаюсь изменить пример диаграммы с накоплением для NVD3. Я могу нарисовать график с моими собственными данными, и все работает отлично. Однако, похоже, что синтаксический анализ данных работает неправильно. Как и в примере с NVD3, я конвертировал свои даты во время Unix, как в примерах с NVD3, и это первые значения в данных. Вторые значения - это количество. Данные хорошо рисуются, но все даты указаны как 17.01.1970. Пример можно увидеть здесь.

Мои данные выглядят так:

var data = [
{'values': [[1403236800, 573], [1403323200, 632], [1403409600, 691],
    [1403496000, 882], [1403582400, 898], [1403668800, 869], [1403755200, 853],
    [1403841600, 787], [1403928000, 596], [1404014400, 505], [1404100800, 877],
    [1404187200, 813], [1404273600, 816], [1404360000, 754], [1404446400, 765],
    [1404532800, 531], [1404619200, 501], [1404705600, 786], [1404792000, 840],
    [1404878400, 963], [1404964800, 857], [1405051200, 909], [1405137600, 620],
    [1405224000, 694], [1405310400, 879], [1405396800, 926], [1405483200, 895],
    [1405569600, 1044], [1405656000, 1201], [1405742400, 869], [1405828800, 757],
    [1405915200, 1048], [1406001600, 972], [1406088000, 889], [1406174400, 941],
    [1406260800, 641], [1406347200, 477], [1406433600, 538], [1406520000, 780],
    [1406606400, 873], [1406692800, 757], [1406779200, 427], [1406865600, 37]],
    'key': 'Stream1'},
{'values': [[1403236800, 782], [1403323200, 843], [1403409600, 791],
    [1403496000, 1020], [1403582400, 1059], [1403668800, 1062], [1403755200, 1231],
    [1403841600, 1235], [1403928000, 801], [1404014400, 689],
    [1404100800, 1095], [1404187200, 908], [1404273600, 972], [1404360000, 924],
    [1404446400, 775], [1404532800, 381], [1404619200, 488], [1404705600, 895],
    [1404792000, 1081], [1404878400, 1035], [1404964800, 923],
    [1405051200, 1036], [1405137600, 736], [1405224000, 803], [1405310400, 985],
    [1405396800, 1186], [1405483200, 1095], [1405569600, 1328],
    [1405656000, 1229], [1405742400, 1218], [1405828800, 787], [1405915200, 1164],
    [1406001600, 1100], [1406088000, 1197], [1406174400, 927], [1406260800, 803],
    [1406347200, 670], [1406433600, 588], [1406520000, 850], [1406606400, 780],
    [1406692800, 699], [1406779200, 488], [1406865600, 37]],
    'key': 'Stream2'},
{'values': [[1403236800, 211], [1403323200, 211], [1403409600, 294], 
[1403496000, 367], [1403582400, 373], [1403668800, 361], [1403755200, 404],
    [1403841600, 450], [1403928000, 309], [1404014400, 245], [1404100800, 328],
    [1404187200, 431], [1404273600, 329], [1404360000, 348], [1404446400, 361],
    [1404532800, 184], [1404619200, 127], [1404705600, 236], [1404792000, 277],
    [1404878400, 333], [1404964800, 347], [1405051200, 301], [1405137600, 248],
    [1405224000, 253], [1405310400, 328], [1405396800, 369], [1405483200, 330],
    [1405569600, 444], [1405656000, 429], [1405742400, 313], [1405828800, 322],
    [1405915200, 346], [1406001600, 408], [1406088000, 376], [1406174400, 293],
    [1406260800, 249], [1406347200, 246], [1406433600, 212], [1406520000, 304],
    [1406606400, 316], [1406692800, 283], [1406779200, 180], [1406865600, 13]],
'key': 'Stream3'},
{'values': [[1403236800, 209], [1403323200, 303], [1403409600, 236],
    [1403496000, 341], [1403582400, 310], [1403668800, 361], [1403755200, 342],
    [1403841600, 335], [1403928000, 196], [1404014400, 197], [1404100800, 361],
    [1404187200, 368], [1404273600, 360], [1404360000, 345], [1404446400, 313],
    [1404532800, 174], [1404619200, 205], [1404705600, 294], [1404792000, 345],
    [1404878400, 382], [1404964800, 326], [1405051200, 436], [1405137600, 274],
    [1405224000, 251], [1405310400, 330], [1405396800, 365], [1405483200, 408],
    [1405569600, 517], [1405656000, 542], [1405742400, 438], [1405828800, 451],
    [1405915200, 511], [1406001600, 521], [1406088000, 376], [1406174400, 363],
    [1406260800, 282], [1406347200, 235], [1406433600, 268], [1406520000, 352],
    [1406606400, 425], [1406692800, 371], [1406779200, 210], [1406865600, 17]],
    'key': 'Stream4'},
{'values': [[1403236800, 251], [1403323200, 368], [1403409600, 356],
    [1403496000, 469], [1403582400, 456], [1403668800, 515], [1403755200, 509],
    [1403841600, 422], [1403928000, 290], [1404014400, 328], [1404100800, 467],
    [1404187200, 437], [1404273600, 505], [1404360000, 410], [1404446400, 434],
    [1404532800, 309], [1404619200, 330], [1404705600, 458], [1404792000, 423],
    [1404878400, 478], [1404964800, 507], [1405051200, 484], [1405137600, 319],
    [1405224000, 422], [1405310400, 475], [1405396800, 412], [1405483200, 511],
    [1405569600, 536], [1405656000, 551], [1405742400, 434], [1405828800, 451],
    [1405915200, 511], [1406001600, 503], [1406088000, 449], [1406174400, 433],
    [1406260800, 300], [1406347200, 272], [1406433600, 297], [1406520000, 454],
    [1406606400, 381], [1406692800, 400], [1406779200, 212], [1406865600, 18]],
    'key': 'Stream5'}];

Javascript это:

var colors = d3.scale.category20();
keyColor = function(d, i) {return colors(d.key)};

var chart;
nv.addGraph(function() {
  chart = nv.models.stackedAreaChart()
                .useInteractiveGuideline(true)
                .x(function(d) { return d[0] })
                .y(function(d) { return d[1] })
                .color(keyColor)
                .transitionDuration(300);

  chart.xAxis
      .tickFormat(function(d) { return d3.time.format('%x')(new Date(d)) });

  chart.yAxis
      .tickFormat(d3.format(',f'));

  d3.select('#chart1')
    .datum(data)
    .transition().duration(1000)
    .call(chart)
    .each('start', function() {
        setTimeout(function() {
            d3.selectAll('#chart1 *').each(function() {
              console.log('start',this.__transition__, this)
              if(this.__transition__)
                this.__transition__.duration = 1;
            })
          }, 0)
      })

  nv.utils.windowResize(chart.update);
 });

  return chart;
});

Я также попытался изменить вещи, как показано в ответе здесь, как показано ниже, но это тоже не работает.

var chart;
nv.addGraph(function() {
  chart = nv.models.stackedAreaChart()
                .useInteractiveGuideline(true)
                .x(function(d) { return new Date(d[0]); })
                .y(function(d) { return d[1] })
                .color(keyColor)
                .transitionDuration(300);

  chart.xScale = d3.time.scale();
  chart.xAxis
      .tickFormat(function(d) { return d3.time.format('%x')(new Date(d)) });

  chart.yAxis
      .tickFormat(d3.format(',f'));

2 ответа

Очевидно, d3 использует 13-значную временную метку Unix (включая микросекунды), и у вас есть 10-значная временная метка Unix. попробуйте сделать это:

.tickFormat(function(d) { return d3.time.format('%x')(new Date(d*1000)) });

"Проблема" с данными. Я изменил форматирование даты с предположения "%m/%d/%Y" на "%H:%M:%S". Вот изменение кода:

chart.xAxis.tickFormat(function (d) {
    // changed from %x to %X
    // see https://github.com/mbostock/d3/wiki/Time-Formatting#user-content-format
    return d3.time.format('%X')(new Date(d))
});

Я создал FIDDLE для вас, чтобы проверить.

Другие вопросы по тегам