<bdo id='6Ggos'></bdo><ul id='6Ggos'></ul>
<legend id='6Ggos'><style id='6Ggos'><dir id='6Ggos'><q id='6Ggos'></q></dir></style></legend>

    <small id='6Ggos'></small><noframes id='6Ggos'>

    <i id='6Ggos'><tr id='6Ggos'><dt id='6Ggos'><q id='6Ggos'><span id='6Ggos'><b id='6Ggos'><form id='6Ggos'><ins id='6Ggos'></ins><ul id='6Ggos'></ul><sub id='6Ggos'></sub></form><legend id='6Ggos'></legend><bdo id='6Ggos'><pre id='6Ggos'><center id='6Ggos'></center></pre></bdo></b><th id='6Ggos'></th></span></q></dt></tr></i><div id='6Ggos'><tfoot id='6Ggos'></tfoot><dl id='6Ggos'><fieldset id='6Ggos'></fieldset></dl></div>
    1. <tfoot id='6Ggos'></tfoot>

        如何在 react 项目中隐藏 chart.js 中的图例?

        How to hide the legend in chart.js in a react project?(如何在 react 项目中隐藏 chart.js 中的图例?)
          <tbody id='DdxH5'></tbody>
        <tfoot id='DdxH5'></tfoot>
        <legend id='DdxH5'><style id='DdxH5'><dir id='DdxH5'><q id='DdxH5'></q></dir></style></legend>
        • <small id='DdxH5'></small><noframes id='DdxH5'>

              <i id='DdxH5'><tr id='DdxH5'><dt id='DdxH5'><q id='DdxH5'><span id='DdxH5'><b id='DdxH5'><form id='DdxH5'><ins id='DdxH5'></ins><ul id='DdxH5'></ul><sub id='DdxH5'></sub></form><legend id='DdxH5'></legend><bdo id='DdxH5'><pre id='DdxH5'><center id='DdxH5'></center></pre></bdo></b><th id='DdxH5'></th></span></q></dt></tr></i><div id='DdxH5'><tfoot id='DdxH5'></tfoot><dl id='DdxH5'><fieldset id='DdxH5'></fieldset></dl></div>
                  <bdo id='DdxH5'></bdo><ul id='DdxH5'></ul>

                  本文介绍了如何在 react 项目中隐藏 chart.js 中的图例?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在尝试隐藏使用 Chart.js 创建的图表的图例.

                  根据官方文档(

                  解决方案

                  如文档中所述,您将配置图例的命名空间链接为:options.plugins.legend,如果你把它它会在那里工作:

                  var options = {类型:'线',数据: {标签:[红色",蓝色",黄色",绿色",紫色",橙色"],数据集:[{标签:'投票数',数据:[12、19、3、5、2、3],边框颜色:'粉红色'}]},选项: {插件:{传奇: {显示:假}}}}var ctx = document.getElementById('chartJSContainer').getContext('2d');新图表(ctx,选项);

                  <body><canvas id="chartJSContainer" width="600" height="400"></canvas><script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.5.0/chart.js"></script></body>

                  另一方面,您的选项对象的很大一部分是错误的,当您使用 v3 时,它是 V2 语法,请查看 迁移指南

                  您在图例中得到 undefined 作为文本的原因是,您没有在数据集中提供任何 label 参数.

                  I am trying to hide the legend of my chart created with Chart.js.

                  According to the official documentation (https://www.chartjs.org/docs/latest/configuration/legend.html), to hide the legend, the display property of the options.display object must be set to false.

                  I have tried to do it in the following way:

                  const options = {
                      legend: {
                          display: false,
                      }
                  };
                  

                  But it doesn't work, my legend is still there. I even tried this other way, but unfortunately, without success.

                  const options = {
                      legend: {
                          display: false,
                              labels: {
                                  display: false
                              }
                          }
                      }
                  };
                  

                  This is my full code.

                  import React, { useEffect, useState } from 'react';
                  import { Line } from "react-chartjs-2";
                  import numeral from 'numeral';
                  
                  const options = {
                      legend: {
                          display: false,
                      },
                      elements: {
                          point: {
                              radius: 1,
                          },
                      },
                      maintainAspectRatio: false,
                      tooltips: {
                          mode: "index",
                          intersect: false,
                          callbacks: {
                              label: function (tooltipItem, data) {
                                  return numeral(tooltipItem.value).format("+0,000");
                              },
                          },
                      },
                      scales: {
                          xAxes: [
                              {
                                  type: "time",
                                  time: {
                                      format: "DD/MM/YY",
                                      tooltipFormat: "ll",
                                  },
                              },
                          ],
                          yAxes: [
                              {
                                  gridLines: {
                                      display: false,
                                  },
                                  ticks: {
                                      callback: function(value, index, values) {
                                          return numeral(value).format("0a");
                                      },
                                  },
                              },
                          ],
                      },
                  };
                  
                  const buildChartData = (data, casesType = "cases") => {
                      let chartData = [];
                      let lastDataPoint;
                  
                      for(let date in data.cases) {
                          if (lastDataPoint) {
                              let newDataPoint = {
                                  x: date,
                                  y: data[casesType][date] - lastDataPoint
                              }
                              chartData.push(newDataPoint);
                          }
                          lastDataPoint = data[casesType][date];
                      }
                      return chartData;
                  };
                  
                  function LineGraph({ casesType }) {
                  
                      const [data, setData] = useState({});
                  
                      useEffect(() => {
                          const fetchData = async() => {
                              await fetch("https://disease.sh/v3/covid-19/historical/all?lastdays=120")
                              .then ((response) => {
                                  return response.json();
                              })
                              .then((data) => {
                                  let chartData = buildChartData(data, casesType);
                                  setData(chartData);
                              });
                          };
                          fetchData();
                      }, [casesType]);
                  
                      return (
                          <div>
                              {data?.length > 0 && (
                              <Line 
                                  data={{
                                      datasets: [
                                          {
                                              backgroundColor: "rgba(204, 16, 52, 0.5)",
                                              borderColor: "#CC1034",
                                              data: data
                                          },
                                      ],
                                  }}
                                  options={options}
                              />
                              )}
                          </div>
                      );
                  }
                  
                  export default LineGraph;
                  

                  Could someone help me? Thank you in advance!

                  PD: Maybe is useful to try to find a solution, but I get 'undefined' in the text of my legend and when I try to change the text like this, the text legend still appearing as 'Undefindex'.

                  const options = {
                      legend: {
                          display: true,
                          text: 'Hello!'
                      }
                  };
                  

                  解决方案

                  As described in the documentation you linked the namespace where the legend is configured is: options.plugins.legend, if you put it there it will work:

                  var options = {
                    type: 'line',
                    data: {
                      labels: ["Red", "Blue", "Yellow", "Green", "Purple", "Orange"],
                      datasets: [{
                          label: '# of Votes',
                          data: [12, 19, 3, 5, 2, 3],
                          borderColor: 'pink'
                        }
                      ]
                    },
                    options: {
                      plugins: {
                        legend: {
                          display: false
                        }
                      }
                    }
                  }
                  
                  var ctx = document.getElementById('chartJSContainer').getContext('2d');
                  new Chart(ctx, options);

                  <body>
                    <canvas id="chartJSContainer" width="600" height="400"></canvas>
                    <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.5.0/chart.js"></script>
                  </body>

                  On another note, a big part of your options object is wrong, its in V2 syntax while you are using v3, please take a look at the migration guide

                  Reason why you get undefined as text in your legend is, is because you dont supply any label argument in your dataset.

                  这篇关于如何在 react 项目中隐藏 chart.js 中的图例?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  ChartJS Version 3 - common legend for multiple line charts(ChartJS 版本 3 - 多个折线图的常用图例)
                  Charts.js scales yaxes ticks min max doesnt work(Charts.js 缩放 yaxes 刻度 min max 不起作用)
                  How to expand the slice of donut chart in chartjs?(如何在chartjs中扩展圆环图的切片?)
                  Chart.js yAxes Ticks stepSize not working (fiddle)(Chart.js yAxes Ticks stepSize 不起作用(小提琴))
                  Rounded corners on chartJS v.2 - bar charts (with negative values)(chartJS v.2 上的圆角 - 条形图(带负值))
                  How to hide value in Chart JS bar(如何在 Chart JS 栏中隐藏值)
                  1. <i id='gRgDo'><tr id='gRgDo'><dt id='gRgDo'><q id='gRgDo'><span id='gRgDo'><b id='gRgDo'><form id='gRgDo'><ins id='gRgDo'></ins><ul id='gRgDo'></ul><sub id='gRgDo'></sub></form><legend id='gRgDo'></legend><bdo id='gRgDo'><pre id='gRgDo'><center id='gRgDo'></center></pre></bdo></b><th id='gRgDo'></th></span></q></dt></tr></i><div id='gRgDo'><tfoot id='gRgDo'></tfoot><dl id='gRgDo'><fieldset id='gRgDo'></fieldset></dl></div>

                        <tbody id='gRgDo'></tbody>
                        <bdo id='gRgDo'></bdo><ul id='gRgDo'></ul>

                            <small id='gRgDo'></small><noframes id='gRgDo'>

                            <legend id='gRgDo'><style id='gRgDo'><dir id='gRgDo'><q id='gRgDo'></q></dir></style></legend><tfoot id='gRgDo'></tfoot>