开发者问题收集

React hooks 没有正确设置 JSON API 响应

2022-02-21
276

我尝试将我的钩子设置为 useState(null) useState([]) 和 useState() 以进行初始页面加载,但均未成功。

fetch 方法中的 result.data 和 result.labels 均使用适当的数据记录到控制台,但每次我调用 setGraphData 或 setGraphLabels 时,它都拒绝将数据传输到钩子变量

JSON 响应:

成功 true

标签 [ “Jan”, “Feb”, “Mar”, “Apr”, “May”, “Jun”, “Jul”, “Aug”, “Sep”, “Oct”, … ]

数据 [ {…}, {…}, {…}, {…} ]

0 对象 { 标签:“”, 数据:null, borderColor:“”, …

1 对象 { 标签:“Kyle”, borderColor:“#f6ff00”, backgroundColor:“#f6ff00”, …

标签“Kyle”

数据 [“1517”,“1689”,“1719”,“1591”,“1490”,“1310”,“1533”,“1500”,“1400”,“1300”,… ]

borderColor“#f6ff00”

backgroundColor“#f6ff00”

2 对象 { 标签:“Biprodeep”,borderColor:“#ff0000”,backgroundColor:“#ff0000”,…

3 对象 { 标签:“Archisman”,borderColor:“#001eff”,backgroundColor:“#001eff”,…

import React from 'react';
import { Line } from 'react-chartjs-2';
import {
  Chart as ChartJS,
  CategoryScale,
  LinearScale,
  PointElement,
  LineElement,
  Title,
  Tooltip,
  Legend,
} from 'chart.js'
import { Chart } from 'react-chartjs-2'

ChartJS.register(
  CategoryScale,
  LinearScale,
  PointElement,
  LineElement,
  Title,
  Tooltip,
  Legend
)

function UploadFile() {

  const [graphData, setGraphData] = React.useState(null);
  const [graphDataFinal, setGraphDataFinal] = React.useState(null);
  const [graphLabels, setGraphLabels] = React.useState(null);
  const [isUploaded, setIsUploaded] = React.useState(false);
  var graphDataSets = [];

  function dropHandler(ev) {
    console.log('File(s) dropped');
  
    // Prevent default behavior (Prevent file from being opened)
    if (ev.dataTransfer.items) {
        // If dropped items aren't files, reject them
        if (ev.dataTransfer.items[0].kind === 'file') {
          var file = ev.dataTransfer.items[0].getAsFile();
          var data = new FormData()
          data.append('file', file)

          fetch('http://192.168.1.94:8081/upload', {
            method: 'post',
            body: data,
            headers: {
              'Authorization': localStorage.getItem('session-id')
            },
        }).then(response => response.json())
        .then(
          (result) => {
            DrawGraph(result.data, result.labels);
            setIsUploaded(true);
          },
          // Note: it's important to handle errors here
          // instead of a catch() block so that we don't swallow
          // exceptions from actual bugs in components.
          (error) => {
            console.log(error);
          }
        );
        }
    }
    ev.preventDefault();
    }

  function dragOverHandler(ev) {
    console.log('File(s) in drop zone');
  
    // Prevent default behavior (Prevent file from being opened)
    ev.preventDefault();
  }

  function DrawGraph(data, labels) {
    console.log("Draw Graph Executed")
    setGraphData(data);
    setGraphLabels(labels);
    for (var x in graphData) {
      if (x === 0) {
        
      } else {
        graphDataSets.push({ id: x, label: graphData[x].label, data: graphData[x].data, borderColor: graphData[x].borderColor, backgroundColor: graphData[x].backgroundColor })
      }
    }
    setGraphDataFinal(graphDataSets);
    console.log(graphDataFinal);
  }

  return (
    <div>
      <div id="drop_zone" onDrop={dropHandler} onDragOver={dragOverHandler}>
        <p className="drop_zone">Drag one or more files to upload and generate a graph</p>
      </div>
      <br></br>
        {isUploaded ? <div className="graph-area"><Line
          datasetIdKey='myLine'
          data={{
            labels: graphLabels,
            datasets: graphDataFinal,
          }}
        /></div> : null}
    </div>
    )
}

export default UploadFile
1个回答

React 不会立即更新状态,因此在绘制图形的函数中使用 for 循环中的数据变量而不是 graphData,并更新代码,以便立即生效/改变状态。

function DrawGraph(data, labels) {
console.log("Draw Graph Executed")
setGraphData(data);
setGraphLabels(labels);
for (var x in data) {
  if (x === 0) {
    
  } else {
    graphDataSets.push({ id: x, label: graphData[x].label, data: graphData[x].data, borderColor: graphData[x].borderColor, backgroundColor: graphData[x].backgroundColor })
  }
}
setGraphDataFinal(graphDataSets);
console.log(graphDataSets);
}
Asad Haroon
2022-02-21