首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >找到(.)使用动态url使用next.js获取数据时未定义。

找到(.)使用动态url使用next.js获取数据时未定义。
EN

Stack Overflow用户
提问于 2022-05-26 17:59:35
回答 2查看 381关注 0票数 0

当我在主页面中获取数据时,一切都按我的要求工作,但是当我使用相同的代码在另一个文件夹中使用动态url时,当我试图在数组上使用方法时,会出现一个错误。当我console.log获取数据时,得到的数组与主页中的数组相同。

当我删除链接而只想看到book.title时,它可以工作。但是当我想从资源中获取数据时,我遇到了错误。

mainpage.js

代码语言:javascript
运行
复制
const [data, setData] = useState(null);
const [isLoading, setLoading] = useState(false);

useEffect(() => {
  setLoading(true);
  fetch('https://gnikdroy.pythonanywhere.com/api/book')
    .then((res) => res.json())
    .then((data) => {
      setData(data);
      setLoading(false);
    });
}, []);

return(
       <div>
        {data.results.map((book, index) => (
          <div key={index}>
            <h1>{book.title}</h1>
            <Link href={`/reader/${book.id}`} passHref>
              <h2>
                {
                  book.resources.find(
                    ({ type }) => type === 'application/epub+zip'
                  ).uri
                }
              </h2>
            </Link>
          </div>
        ))}
      </div>
)

searchPage.js

代码语言:javascript
运行
复制
const router = useRouter();
const { name } = router.query;
const [data, setData] = useState(null);
const [loading, setLoading] = useState(false);

useEffect(() => {
  setLoading(true);
  fetch(`https://gnikdroy.pythonanywhere.com/api/book/?search=${name}`)
    .then((res) => res.json())
    .then((data) => {
      setData(data);
      setLoading(false);
      console.log(data);
    });
}, []);

return(
      <div>
        {data.results.map((book, index) => (
          <div key={index}>
            <h1>{book.title}</h1>
            <Link href={`/reader/${book.id}`} passHref>
              <h2>
                {
                  book.resources.find(
                    ({ type }) => type === 'application/epub+zip'
                  ).uri
                }
              </h2>
            </Link>
          </div>
        ))}
      </div>
)

我的console.log内置searchPage.js

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-05-26 18:07:15

您的响应数据有时不会获取资源字段。

这就是为什么book.resources可以是未定义(或) null的原因。

您可以很容易地使用可选的更改(?)

取代:

代码语言:javascript
运行
复制
{
   book.resources?.find(
     ({ type }) => type === 'application/epub+zip'
   )?.uri || ''
}
票数 3
EN

Stack Overflow用户

发布于 2022-05-26 18:46:36

除了吴宇的回答外,当考虑如何呈现代码时,

首先只在页面加载时执行return,然后才执行useEffect,因为useEffect依赖数组中没有值。

因此,在您的场景中,初始页面加载中有data = null。因此,当呈现下面的代码时,因为data = null data.results不能使用Arrays.map()。

然后执行useEffect,并在其中设置从API调用返回的值,并将该值设置为data。

为了避免呈现未定义的错误,您必须确保data.results不等于空/未定义,并且在存在data.results时呈现所需的内容。

你可以通过以下方式实现这一点。

  1. 可选链式运算符(?)吴吴的回答简化了当引用或函数可能是undefined or null时通过连接的对象访问值。当book.resources等于空/未定义时,它不会给出上述错误。
  2. 只有当data.resultsbook.resources有值时才呈现,否则如下所示。 //此处有条件地检查是否存在data?.results值,如果存在,则呈现此值。{data?.results && data.results.map((图书,索引) => ( {book.title} /reader/${book.id}} passHref> ]) {/*,这里也有条件地检查book?.resources是否有值,如果存在,则呈现此值。*/} { book?.resources && book.resources.find( ({ type }) =>类型=== 'application/epub+zip‘).uri })}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72396129

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档