我正在尝试使用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限制呈现的数量以防止无限循环
我应该怎样做才能在我网页上看到图表?
1条答案
按热度按时间aij0ehis1#
您需要向
useEffect
添加一个依赖项数组。从依赖项数组中排除项可能会导致无限的更新链。添加dependency数组作为
useEffect
的第二个参数:想只运行一次效果吗?
如果你想运行一个效果并只清理它一次(在挂载和卸载时),你可以传递一个空数组([])作为第二个参数。这告诉React你的效果不依赖于任何props或state的值,所以它永远不需要重新运行。这不是一个特殊情况-它直接遵循依赖关系数组的工作方式。
更多信息,请访问docs