React中ChartJS抛出'也可能重新呈现'

gupuwyp2  于 2022-11-07  发布在  Chart.js
关注(0)|答案(1)|浏览(146)

我正在尝试使用ChartJS创建条形图。当我启动我的应用程序时,网页上没有任何内容,控制台中出现一些错误:'未捕获的错误:重新呈现太多。React会限制呈现的数目,以防止无限循环。'
我代码:

import {
  Chart as ChartJS,
  CategoryScale,
  LinearScale,
  BarElement,
  Title,
  Tooltip,
  Legend
} from 'chart.js'
import {Bar} from 'react-chartjs-2'
import React, {useState, useEffect} from 'react'

ChartJS.register(
  CategoryScale,
  LinearScale,
  BarElement,
  Title,
  Tooltip,
  Legend
);

function App() {

  const [chartData, setChartData] = useState({
    datasets:[],
  })

  const [chartOptions, setChartOptions] = useState({});

  useEffect(()=>{
    setChartData({
      labels: ['john','kevin','george','mike','oreo'],
      datasets:[
        {
          label: 'label',
          data: [12,55,34,120,720],
          borderColor: 'green',
          backgroundColor: 'blue',
        },
      ],
    })
  },[])
  setChartOptions({
    responsive:true,
    plugins:{
      legend:{
        position:'top'
      },
      title:{
        display:true,
        text:'text from tittle'
      }
    }
  })

  return (
    <div className="App">
      <Bar options={chartOptions} data={chartData}/>
    </div>
  );
}

错误:重新呈现太多。React限制呈现的数量以防止无限循环
我应该怎样做才能在我网页上看到图表?

aij0ehis

aij0ehis1#

您需要向useEffect添加一个依赖项数组。从依赖项数组中排除项可能会导致无限的更新链。
添加dependency数组作为useEffect的第二个参数:

useEffect(()=>{
    setChartData({
      labels: ['john','kevin','george','mike','oreo'],
      datasets:[
        {
          label: 'label',
          data: [12,55,34,120,720],
          borderColor: 'green',
          backgroundColor: 'blue',
        },
      ],
    })
  },[])
  setChartOptions({
    responsive:true,
    plugins:{
      legend:{
        position:'top'
      },
      title:{
        display:true,
        text:'text from tittle'
      }
    }
  }, [chartOptions, chartData]) // effect will run when either changes

想只运行一次效果吗?
如果你想运行一个效果并只清理它一次(在挂载和卸载时),你可以传递一个空数组([])作为第二个参数。这告诉React你的效果不依赖于任何props或state的值,所以它永远不需要重新运行。这不是一个特殊情况-它直接遵循依赖关系数组的工作方式。
更多信息,请访问docs

相关问题