为什么同组渲染不出正确的折线图和对应的范围图?

Why doesn't the same group render a correct line chart and corresponding range chart?

Fiddle 这里:https://jsfiddle.net/8yf7j3k6/11/

我正在尝试为我的范围图表引入类似的数据表示,以便我可以在范围图表上擦洗,但在实际的流通数据折线图中使用工具提示。目前,我认为我有两个问题破坏了我的交叉过滤器并导致范围图表看起来很奇怪:

  1. 如果我使用 crossfilter 生成的标准组,我最终得到的值是(流通数据 * number_of_regions_in_which_magazine_was_circulated)。为了绕过这个,我创建了一个地图来跟踪区域的数量,并划分代表的值。我不知道如何为此创建一个组,并在数据级别处理它。因此,我只是在渲染步骤中进行修正 - 这可能是我遇到麻烦的原因吗?

  2. 我为折线图和范围图使用了完全相同的组。在 NASDAQ sample 中,他们似乎以不同的方式处理数据,但似乎他们只是以不同的方式对数据进行分箱,而不是进行重大更改。我不明白为什么我的图表在零点处有如此显着的负值。

下面违规图表的代码。请注意,fiddle 中有一些样板需要处理,因为日期格式

没有 CDN
    lineChart1
      .width(lineChart1Width-50)
      .height(lineChart1Height-50)
      .xUnits(d3.timeMonths)
      .margins({ top: 10, right: 10, bottom: 20, left: 80 })
      .dimension(dimension1)
      .rangeChart(lineChart1Range)
      .group(circulationGroup1)
      .colors(colorScales.blue[colorScales.blue.length - 1])
      .elasticY(true)
      .brushOn(false)
      .valueAccessor(function (d) {
          return d.value / circulationValuesMap[d.key]
      })
      .title(function (d) {
          return `${d.key.format('mmm dd, yyyy')}\nCirculation: ${d.value / circulationValuesMap[d.key]} `
      })
      .x(d3.scaleTime().domain([new Date(1925, 0, 1), new Date(1927, 0, 1)]))
      .render()


    lineChart1Range
      .width(getWidth('line-chart-1-range')) /* dc.barChart('#monthly-volume-chart', 'chartGroup'); */
      .height(40)
      .margins({top: 0, right: 50, bottom: 20, left: 80})
      .dimension(dimension1)
      .group(circulationGroup1)
      .valueAccessor(d => d.value / circulationValuesMap[d.key])
      .centerBar(true)
      .x(d3.scaleTime().domain([new Date(1925, 0, 1), new Date(1927, 0, 1)]))
      .round(d3.timeMonth.round)
      .alwaysUseRounding(true)
      .xUnits(() => 200);

    lineChart1Range.yAxis().ticks(0)

问题是你的CSS。

此规则适用于每个 任何元素的第一个子元素.line-chart-container,也适用于笔刷覆盖.

.line-chart-container :nth-child(1) {
  height: 15em;
}

:nth-child(2)也是如此。

替换实际 div 元素的 2 CSS 高度规则

#line-chart-1 {
  height: 15em;
}
#line-chart-1-range {
  height: 2em;
}

删除 2 个大条。

而且你的折线图和范围图没有对齐,它们的宽度和边距不同。

lineChart1Range
  //.width(getWidth('line-chart-1-range')) /* dc.barChart('#monthly-volume-chart', 'chartGroup'); */
  .width(lineChart1Width-50)
  .height(40)
  //.margins({top: 0, right: 50, bottom: 20, left: 80})
  .margins({top: 0, right: 10, bottom: 20, left: 80})
  .dimension(dimension1)
  .group(circulationGroup1)
  .valueAccessor(d => d.value / circulationValuesMap[d.key])
  .centerBar(true)
  .x(d3.scaleTime().domain([new Date(1925, 0, 1), new Date(1927, 0, 1)]))
  .round(d3.timeMonth.round)
  .alwaysUseRounding(true)
  .xUnits(() => 200);

所有的栏都有工具提示,你看不到它们,因为画笔正在捕捉所有的鼠标事件。也许可以禁用此图表的工具提示