【问题标题】:Horizontal overlapping of bars, not whole graph条形的水平重叠,而不是整个图
【发布时间】:2020-09-21 10:23:04
【问题描述】:

我被要求创建一个类似于上面的条形图,我想知道它是否可以在 chart.js 中实现?我查看了许多站点(例如Overlapping Bar Chart using Chart.jshttps://github.com/chartjs/Chart.js/issues/5224),但我的想法是直接在彼此后面放置两个图形 - 我需要能够设置块的位置(即几乎像我在 CSS 中那样去margin-left:-5px 之类的东西)——或者至少有一些重叠(或大约 40% 的重叠)。如果不是,我可能必须用 CSS 构建它,但使用 Chart JS 会很棒。

【问题讨论】:

  • 我对您帖子的标题和您添加到其中的图片感到困惑。标题提到了水平条形图,但图像显示了垂直条形图。你能澄清一下吗?
  • 但是条形图是水平重叠的——是的,虽然它是一个垂直图
  • 对不起,我的错。这很清楚。

标签: chart.js


【解决方案1】:

Plugin Core API 提供了一系列可用于执行自定义代码的挂钩。您可以使用afterUpdate 挂钩将各个数据集的条形移动所需的像素数,如下所示:

afterUpdate: function(chart) {
  let datasets = chart.config.data.datasets;
  for (let iDs = 1; iDs < datasets.length; iDs++) {
    let dataset = datasets[iDs];
    for (var i = 0; i < dataset._meta[0].data.length; i++) {
      let model = dataset._meta[0].data[i]._model;
      model.x += iDs * offset;
      model.controlPointNextX += iDs * offset;
      model.controlPointPreviousX += iDs * offset;
    }
  }
}

请看下面的可运行代码sn-p,看看它是如何工作的。

const offset = 12;

new Chart('myChart', {
  type: 'bar',
  plugins: [{
    afterUpdate: function(chart) {
      let datasets = chart.config.data.datasets;
      for (let iDs = 1; iDs < datasets.length; iDs++) {
        let dataset = datasets[iDs];
        for (var i = 0; i < dataset._meta[0].data.length; i++) {
          let model = dataset._meta[0].data[i]._model;
          model.x += iDs * offset;
          model.controlPointNextX += iDs * offset;
          model.controlPointPreviousX += iDs * offset;
        }
      }
    }
  }],
  data: {
    labels: ["A"],
    datasets: [{
        label: 'X',
        backgroundColor: 'orange',
        borderWidth: 1,
        data: [5],
        xAxisID: "bar-x-axis1",
        barThickness: 30,
      },
      {
        label: 'Y',
        backgroundColor: 'red',
        data: [10],
        xAxisID: "bar-x-axis2",
        barThickness: 30,
      },
      {
        label: 'Z',
        backgroundColor: 'lightblue',
        data: [15],
        xAxisID: "bar-x-axis3",
        barThickness: 30,
      }
    ]
  },
  options: {
    legend: {
      display: false
    },
    scales: {
      xAxes: [{
          id: "bar-x-axis3",
          display: false
        },
        {
          id: "bar-x-axis2",
          offset: true,
          display: false
        },
        {
          id: "bar-x-axis1",
          offset: true,
          ticks: {
            display: false
          }
        }
      ],
      yAxes: [{
        id: "bar-y-axis1",
        ticks: {
          beginAtZero: true,
          stepSize: 5
        }
      }]
    }
  }
});
canvas {
  max-width: 120px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.min.js"></script>
<canvas id="myChart" height="150"></canvas>

更新

还请检查此answer,它提供了稍微改进的解决方案。

【讨论】:

  • 感谢您的回答 - 很好的回答!它按预期工作,但是我在同一页面上有 2 个图表,我收到错误 Cannot read property 'data' of undefined。我知道这两个图都是独立工作的,但是放在一起似乎会出错?
  • @Anthony:请为这个新问题发布一个新问题,可能带有重现所描述错误的代码示例。这将使想出解决此问题的方法变得容易得多。
  • 我创建了以下 js fiddle。我不确定它是否需要一个新问题? jsfiddle.net/ycpj7g8w
猜你喜欢
  • 2015-01-13
  • 2017-01-20
  • 2012-05-11
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-10-29
  • 2015-02-11
相关资源
最近更新 更多