• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

405
Vistas
React ChartJS: escala el gráfico de barras verticalmente con más conjuntos de datos

Estoy usando React ChartJS para crear un gráfico de barras que actualmente se ve así Gráfico de barras de ReactJS

Los datos sobre los que se construye son dinámicos, es decir, puede haber muchas más industrias (o menos). Me gustaría arreglar el ancho de la barra (digamos, a 30 píxeles) y hacer que el gráfico crezca más alto de acuerdo con la cantidad de conjuntos de datos que tengo. En otras palabras, no me importa qué tan alto sea el gráfico, debería ser una función de cuántos conjuntos de datos tengo.

¿Cómo lograría esto?

Compartiría el código que ya tengo, pero es bastante genérico, puedo publicarlo aquí si la gente lo encuentra útil.

about 3 years ago · Santiago Gelvez
1 Respuestas
Responde la pregunta

0

Primero podría envolver el canvas en un div .

 <div id="chartWrapper"> <canvas id="myChart"></canvas> </div>

Puede hacer uso de la API principal del complemento y calcular la altura del gráfico en el beforeRender según el data.barThickness definido y los conjuntos de datasets visibles.

 plugins: [{ beforeRender : chart => { if (!chart.config.options.nonChartAreaHeight) { var yAxis = chart.scales.y; chart.config.options.nonChartAreaHeight = chart.height - (yAxis.bottom - yAxis.top); } const labelCount = chart.data.labels.length; const datasetCount = chart.data.datasets.map((ds, i) => chart.getDatasetMeta(i)).filter(m => !m.hidden).length; const chartAreaHeight = labelCount * datasetCount * chart.data.barThickness * 1.2; document.getElementById("chartWrapper").style.height = (chartAreaHeight + chart.config.options.nonChartAreaHeight) + 'px'; } }],

Luego, también debe definir option.maintainAspectRatio: false para evitar que Chart.js el tamaño del canvas .

Eche un vistazo al código ejecutable a continuación y vea cómo funciona.

 new Chart('myChart', { type: 'bar', plugins: [{ beforeRender : chart => { if (!chart.config.options.nonChartAreaHeight) { var yAxis = chart.scales.y; chart.config.options.nonChartAreaHeight = chart.height - (yAxis.bottom - yAxis.top); } const labelCount = chart.data.labels.length; const datasetCount = chart.data.datasets.map((ds, i) => chart.getDatasetMeta(i)).filter(m => !m.hidden).length; const chartAreaHeight = labelCount * datasetCount * chart.data.barThickness * 1.2; document.getElementById("chartWrapper").style.height = (chartAreaHeight + chart.config.options.nonChartAreaHeight) + 'px'; } }], data: { labels: ['1', '2', '3', '4'], barThickness: 30, // change this to adapt the bar thickness datasets: [{ label: 'Dataset 1', data: [40, 50, 60, 80], backgroundColor: 'red' }, { label: 'Dataset 2', data: [100, 90, 80, 70], backgroundColor: 'blue' }, { label: 'Dataset 3', data: [60, 80, 70, 90], backgroundColor: 'green' }] }, options: { indexAxis: 'y', maintainAspectRatio: false } });
 div { width: 100%; }
 <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.8.0/chart.min.js"></script> <div id="chartWrapper"> <canvas id="myChart"></canvas> </div>

about 3 years ago · Santiago Gelvez Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda