<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 中的图例?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

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

                  相关文档推荐

                  在开发JS过程中,会经常遇到两个小数相运算的情况,但是运算结果却与预期不同,调试一下发现计算结果竟然有那么长一串尾巴。如下图所示: 产生原因: JavaScript对小数运算会先转成二进制,运算完毕再转回十进制,过程中会有丢失,不过不是所有的小数间运算会
                  问题描述: 在javascript中引用js代码,然后导致反斜杠丢失,发现字符串中的所有\信息丢失。比如在js中引用input type=text onkeyup=value=value.replace(/[^\d]/g,) ,结果导致正则表达式中的\丢失。 问题原因: 该字符串含有\,javascript对字符串进行了转
                  Rails/Javascript: How to inject rails variables into (very) simple javascript(Rails/Javascript:如何将 rails 变量注入(非常)简单的 javascript)
                  quot;Each child in an array should have a unique key propquot; only on first time render of page(“数组中的每个孩子都应该有一个唯一的 key prop仅在第一次呈现页面时)
                  CoffeeScript always returns in anonymous function(CoffeeScript 总是以匿名函数返回)
                  Ordinals in words javascript(javascript中的序数)
                  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>