ChartJS 条形图,带有对应于每个条形图的图例

125*_*748 6 javascript charts canvas chart.js

我试图了解他们条形图上的 ChartJS 文档。它对我来说没有意义,因为顶部的标签在一次意义上看起来好像它只适用于第一个条(基于颜色),而在另一种意义上,整个图表(它是唯一的标签)不在工具提示中,它位于前面和中间)

条形图演示

我一直在努力让它更像他们的折线图,它显示了一个带有标签的图例和一个与图表上每条线相关的彩色方块。(他们没有多线图的例子,但它确实像这样工作)。

数据对象中的标签属性被转换为条形旁边的值,例如 labels: ['36%', '10%', '18%', '34%', '0%', '2%'] 条形图失败

我想要一个顶部的图例,表明浅绿色是苹果,灰色是橙色,绿色是梨,等等,但我来过的最接近的是提供data.datasets一组对象并制作标签和数组,这只会导致酒吧组,就像这里的例子。

Bli*_*n67 6

这样做的方法是在数据集中创建多个项目,每个项目只有一个类别的数据。您可以拥有一个名为 stock 的顶级标签,然后为每种类型创建单独的数据集。

// create a chart.
const ctx = canvas.getContext("2d");
const chart = new Chart(ctx, {
   type: "horizontalBar",
   data: {
      labels: ["Stock"],
      datasets: [{
         label: "Apples",
         backgroundColor: "#AF7",
         data: [Math.random() * 100],
      },{
         label: "Oranges",
         backgroundColor: "#FA4",
         data: [Math.random() * 100],
      },{
         label: "Mangos",
         backgroundColor: "#FF7",
         data: [Math.random() * 100],
      },{
         label: "Avocados",
         backgroundColor: "#2A7",
         data: [Math.random() * 100],
      }]
   },
   options: {
          responsive: false,
          legend: { position: 'top'},
          title: { display: true, text: 'Fruit in stock'}
      }
});
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.5.0/Chart.min.js"></script>
<canvas id=canvas height=200 width=500></canvas>
Run Code Online (Sandbox Code Playgroud)

  • 太好了,谢谢。除了左侧的“Stock”之外,还有没有为每个条形放置单独的标签,例如沿 y 轴向下移动的“18、82、22、80”? (2认同)