【问题标题】:React setState being overwritten within .map()React setState 在 .map() 中被覆盖
【发布时间】:2020-03-03 10:32:18
【问题描述】:

我正在尝试从多个端点动态获取数据并使用 React 挂钩保存到本地状态。当我记录以下内容时,refDataArr 中的每个项目的状态似乎都被覆盖了。

数据正在被正确解析和存储,但我希望refData state 包含所有四个结果,而不是被覆盖。

  useEffect(() => {
    const refDataArr = [
      {
        url: "users",
        field: "user"
      },
      {
        url: "products",
        field: "product"
      },
      {
        url: "roles",
        field: "role"
      },
      {
        url: "locations",
        field: "location"
      }
    ]

    const fetchRefData = () => {
      console.log('Fetching reference data...');
      try {
        refDataArr.map(async (o, index) => {
          let url = o.url
          let field = o.field
          const res = await axios.get(`http://.../${url}/ `);
          const data = res.data.data

          let resArr = Object.values(data).map((item, index) => {
            return {
              key: item._key,
              value: item[field]
            }
          });
          setRefData({
            ...refData, 
            [field]: resArr, 
          })
        })
      } catch (err) {
        console.log(err);
      }
    }
    fetchRefData();
  }, []);

结果日志示例(其他日志显示用户、角色等。它们正在被覆盖):

refData = {
 user: [
  {key: 1, value: "A"},
  {key: 2, value: "B"}
 ]
}

refData = {
 location: [
  {key: 1, value: "A"},
  {key: 2, value: "B"}
 ]
}

...etc

想要的结果:

refData = {
 user: [
  {key: 1, value: "A"},
  {key: 2, value: "B"}
 ],
 product: [
  {key: 1, value: "A"},
  {key: 2, value: "B"}
 ],
 role: [
  {key: 1, value: "A"},
  {key: 2, value: "B"}
 ],
 location: [
  {key: 1, value: "A"},
  {key: 2, value: "B"}
 ]
}

【问题讨论】:

    标签: javascript arrays react-hooks setstate array.prototype.map


    【解决方案1】:

    您应该构建您想要的对象,然后在它完全构建后使用您需要的setRefData

    useEffect(() => {
        const refDataArr = [
          {
            url: "users",
            field: "user"
          },
          {
            url: "products",
            field: "product"
          },
          {
            url: "roles",
            field: "role"
          },
          {
            url: "locations",
            field: "location"
          }
        ]
        let newData = {};
        const fetchRefData = () => {
          console.log('Fetching reference data...');
          try {
            refDataArr.map(async (o, index) => {
              let url = o.url
              let field = o.field
              const res = await axios.get(`http://.../${url}/ `);
              const data = res.data.data
    
              let resArr = Object.values(data).map((item, index) => {
                return {
                  key: item._key,
                  value: item[field]
                }
              });
              newData = {...newData, [field]: [...resArr]}
            })
            setRefData({
              ...refData, 
              ...newData, 
            })
          } catch (err) {
            console.log(err);
          }
        }
        fetchRefData();
      }, []);
    

    【讨论】:

    • 如果你能详细说明会有所帮助
    • 使用您的数据生成一个对象。然后,使用函数setRefData 保存该对象
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-05-29
    • 2018-10-08
    • 1970-01-01
    • 1970-01-01
    • 2021-07-25
    • 2018-11-13
    • 1970-01-01
    相关资源
    最近更新 更多