繁体   English   中英

TypeError:从 API 获取时无法读取未定义的属性“映射”

[英]TypeError: Cannot read property 'map' of undefined while fetching from API

我一直在尝试制作一个简单的 API 获取,但我不明白我做错了什么我已经阅读了很多问题,但我真的觉得我错过了一些东西,因为一切似乎都是正确的(显然不是)

import { useState } from "react";
import ProductCard from "./ArticleCard/ProductCard.js";

export default function ProductsIndex() {
  const [searchText, set_searchText] = useState("");
  const [state, set_state] = useState({ status: "idle" });
  const search = async () => {
    if (searchText === "") {
      set_state({ status: "idle" });
      return;
    }
    set_state({ status: "searching" });
    const queryParam = encodeURIComponent(searchText);
    const data = await fetch(
      /* base browser fetch  https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch*/
      `https://omdbapi.com/?apikey=6a06f383&s=${queryParam}`
    ).then((r) => r.json());
    set_state({ status: "done!", data: data.Search });
  };
  console.log(state.data);
  return (
    <div className="ProductsIndex">
      We sell movies for a high price.
      <h1>Discover some movies!</h1>
      <p>
        <input
          value={searchText}
          onChange={(e) => set_searchText(e.target.value)}
        />
        <button onClick={search}>Search</button>
      </p>{" "}
      <p>
        {state.data.map((movie) => (
          <ProductCard
            poster={movie.poster}
            title={movie.title}
            year={movie.year}
            type={movie.type}
          />
        ))}
      </p>
    </div>
  );
} 

console.log(state.data) 给出了想要的结果,所以就好像数据没有被传递下去..我不明白为什么

来自 console.log(state.data) 的结果:

[
    {
        "Title": "Finding Nemo",
        "Year": "2003",
        "imdbID": "tt0266543",
        "Type": "movie",
        "Poster": "https://m.media-amazon.com/images/M/MV5BZTAzNWZlNmUtZDEzYi00ZjA5LWIwYjEtZGM1NWE1MjE4YWRhXkEyXkFqcGdeQXVyNjU0OTQ0OTY@._V1_SX300.jpg"
    },
    {
        "Title": "Finding Nemo",
        "Year": "2003",
        "imdbID": "tt0401422",
        "Type": "game",
        "Poster": "https://m.media-amazon.com/images/M/MV5BNGEzMjdiZGEtYzU3ZC00OGFmLWI3NTgtZTcyNTFjYTliNDg5XkEyXkFqcGdeQXVyNjExODE1MDc@._V1_SX300.jpg"
    },
    {
        "Title": "Finding Nemo Submarine Voyage",
        "Year": "2007",
        "imdbID": "tt1319713",
        "Type": "movie",
        "Poster": "https://m.media-amazon.com/images/M/MV5BMzAxMzMyODQtNWY0Yy00N2M3LWE5MDQtZDUzNjc1ZGFmMzA4XkEyXkFqcGdeQXVyMzkxMzc4Mw@@._V1_SX300.jpg"
    },
    {
        "Title": "Finding Nemo: Studio Tour of Pixar",
        "Year": "2003",
        "imdbID": "tt1248974",
        "Type": "movie",
        "Poster": "N/A"
    },
    {
        "Title": "Finding Nemo: A Filmmakers' Roundtable",
        "Year": "2012",
        "imdbID": "tt10255922",
        "Type": "movie",
        "Poster": "https://m.media-amazon.com/images/M/MV5BNjAyMTBmODQtZGYxMC00NjdhLThhN2MtODlhMDI4NTczYTMyXkEyXkFqcGdeQXVyNDEyNjEzOTg@._V1_SX300.jpg"
    }
]

谢谢您的帮助

你应该初始化state.data试试这样。

 const [state, set_state] = useState({ status: "idle",data:[] });

我刚刚解决了几件事:

  1. 定义数据状态

const [state, set_state] = useState({ status: "idle",data:[] });

  1. 在迭代之前检查你的数组

    {state.data && state.data.map((movie) => ( <ProductCard poster={movie.poster} title={movie.title} year={movie.year} type={movie.type} /> ))}

我创建了一个小演示:搜索 nemo,按下按钮并请检查控制台, https://codesandbox.io/s/flamboyant-dubinsky-3bxsf?file=/src/App.js:155-219

我想我明白了问题所在,当你设置一个新的 state 时:它会替换以前的。 考虑到这一点,当您像这样设置加载状态时:


set_state({ status: "idle" });

它实际上使您的state.data未定义,因此,它会引发异常。

与其重新分配整个 state,不如尝试仅替换需要更改的内容:

set_state({ ...state, status: "idle" });

所以,每当你调用你的 set_state 方法时,你应该添加你的...state ,所以你不会有这个问题。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM