图表未显示更新的数据

如何解决图表未显示更新的数据

我用过https://www.npmjs.com/package/react-chartjs-2,它第一次显示一个有数据的图表。但是每当我尝试使用新数据和数据集重新绘制时,它总是在图表上显示以前的图形数据。

我尝试过以下解决方案:https://github.com/reactchartjs/react-chartjs-2

也尝试给参考

但是,它仍然显示了它第一次加载的相同数据。

显示图表的代码

 <Line
      data={graphData}
      redraw
      options={options}
      height="100px"
      weight="100px"
 />

在这方面, graphData 是, const [graphData,setGraphData] = useState(data);

重绘, 我也试过,redraw={true}

当数据会被修改时,我使用setGraphData(updatedData)来更新图表,我也检查了数据是否发生了变化。

graphData 中的数据更新但未显示在图表上

其中指定为graphData的认数据的数据,

const data = {
    labels: months,datasets: [
        {
            label: "# of Users",data: [0,64,129,193,258,322,387,451,516,580],fill: false,backgroundColor: "rgb(255,99,132)",borderColor: "rgba(255,132,0.2)",yAxisID: "y-axis-1",},{
            label: "# of Orders",25,50,76,101,126,151,177,202,227],backgroundColor: "rgb(54,162,235)",borderColor: "rgba(54,235,yAxisID: "y-axis-2",],};

我正在创建此数据的副本,然后在 setGraphData() 中进行分配

任何人都可以帮我解决这个问题!提前谢谢你!!

解决方法

没有看到代码,这里只有一个解决方案。提供图表组件的密钥并在数据更新后更新密钥,

<chart key={getKey()} data={data} />

get 键将为新数据创建一个唯一的键。

  const getKey = () => {
    return data?.map((p) => p.id)?.join();
  };

这里唯一重要的是,如果数据更新,getKey 方法应该返回一个新值 JSON.stringify(data) 是最简单的选项(我不确定将序列化数据作为键提供是否是一个好方法,但肯定会起作用)

,

重新渲染背后的问题是一个定义为调用、后端 API 处理程序和将数据分配给折线图的函数。

之前 - 不工作

useEffect(() => {
      ...
      the function which has code to call and fetch data from back-end API/handler
    },[]);

之后 - 工作

useEffect(() => {
       ...
       Code which calls back-end API/handler function to fetch data for graph
       ...
    },[]);

我也一直保持重绘

<Line
     key={JSON.stringify(graphData)}
     data={graphData}
     redraw
     options={options}
     height="100px"
     weight="100px"
 />

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?