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

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

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

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

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

mainpage.js

代码语言:javascript
运行
AI代码解释
复制
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
运行
AI代码解释
复制
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 10:07:15

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

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

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

取代:

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

Stack Overflow用户

发布于 2022-05-26 10: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

复制
相关文章
flask使用request获取表单提交数据和获取url
web开发免不了需要获取用户提交的数据,Flask为我们提供了request对象来获取用户提交给服务器的数据。 下面是一个最基本的获取数据的例子:
菲宇
2022/05/06
3.1K0
如何使用 Go 语言获取 URL?
在 Web 开发和网络爬虫等领域,经常需要获取和处理 URL(统一资源定位符)。Go 语言提供了丰富的标准库来处理 URL,使得获取和解析 URL 变得简单而高效。本文将介绍如何使用 Go 语言获取 URL 的详细步骤,并提供一些实用的示例。
网络技术联盟站
2023/07/03
8350
如何使用 Go 语言获取 URL?
使用jquery获取url及url参数的方法
使用jquery获取url以及使用jquery获取url参数是我们经常要用到的操作
Jensen_97
2023/07/19
1.5K0
前端处理动态 url 和 pushStatus 的使用
起因是这样的,在尝试前后端分离的这条道路上,我自己也在不断摸索,感觉要把大部分的坑都踩踩了。目前我用的技术是:
零式的天空
2022/03/22
1.3K0
如何使用 Go 语言实现并发获取多个 URL?
在进行 Web 开发和网络爬虫等任务时,我们经常需要同时获取多个 URL 上的数据。Go 语言提供了强大的并发编程支持,能够帮助我们高效地实现并发获取多个 URL 的功能。本文将详细介绍如何使用 Go 语言实现并发获取多个 URL 的步骤,以及提供一些实用的示例。
网络技术联盟站
2023/07/03
2900
如何使用 Go 语言实现并发获取多个 URL?
使用JS获取上一页的url地址
上面的代码其实就可以满足我们返回上一页面的需求,但是如果我们是从别的地方打开此链接的时候事实上是没有上一页的,为了提升用户的体验,我们可以使用js来控制当我们点击返回按钮时所进行的操作,关键代码如下:
全栈程序员站长
2022/07/08
6.3K0
Next.js的创建与使用
NextJs是React的服务器渲染框架,区别于官方SSRNext最大的特点是可以渲染出Ajax异步请求渲染出来的结果,本网站目前使用的前端框架就是NextJs
用户6256742
2022/07/06
4.1K0
Next.js的创建与使用
vue中使用scss动态获取js变量
需求: image.png 数据: list: [ { title: "Ⅰ级风险", color: "#ff3333", }, { title: "Ⅱ级风险", color: "#ff9554", }, { title: "Ⅲ级风险", color: "#ba50b0", }, { title: "Ⅳ级风险", color: "#4885fb", }, { title: "无风险", col
4O4
2022/04/15
6.4K0
vue中使用scss动态获取JS变量
vue中使用scss动态获取JS变量 需求: image.png 数据: list: [ { title: "Ⅰ级风险", color: "#ff3333", }, { title: "Ⅱ级风险", color: "#ff9554", }, { title: "Ⅲ级风险", color: "#ba50b0", }, { title: "Ⅳ级风险", color: "#4885fb", }, {
4O4
2022/04/25
5K0
vue中使用scss动态获取JS变量
Django获取URL中的数据
我们将第一种形式称为“URL路径参数”;第二种形式称为“URL关键字形式”。下面讲述如何在Django中获取这两种形式的数据。
zy010101
2021/11/02
5.7K0
通过图片url获取图片数据[通俗易懂]
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/09
2.6K0
使用Python获取Mysql数据
本文由用户 wuxqing 自行上传分享,仅供网友学习交流。所有权归原作者,若您的权利被侵害,请联系管理员。
用户7365393
2021/11/01
2.5K0
使用Python获取Mysql数据
使用Python获取Mysql数据 #!/usr/bin/python -- coding: UTF-8 -- pip install MySQL-python import MySQLdb, os try: conn = MySQLdb.connect(host='172.17.42.1', user='数据库访问用户', passwd='数据库访问密码', db='数据库名', port=3306) cur = conn.cursor() cur.execute('SELECT `id`, `
大师级码师
2021/09/22
2.3K0
如何使用FME获取数据
通过技术手段,来访问通过ArcGIS Server 发布出来的要素数据,并保存到磁盘。 特点:快、简单! 本次推送,不仅有文字内容,更有配套视频,喜欢看片的,可以直接复制链接去看视频资源:https://www.bilibili.com/video/BV1JV411i77Q/ 不过我觉得,配合推送享用更佳哦!
数据处理与分析
2021/03/16
3.2K0
如何使用FME获取数据
listview动态获取数据
1.主Activity 1 public class MainActivity extends Activity { 2 3 private ListView listView; 4 private ArrayList<Person> persons; 5 private ListAdapter adapter; 6 private Handler handler=null; 7 //xml文件的网络地址 8 final String pa
xiangzhihong
2018/01/26
3.2K0
powershell使用udp获取数据
最近开始忙了,所以文章可能多以tips为主,如果短的就用文字,长点的就图文。 nc -lnvup 53 powershell -nop -c "$s=New-Object System.Net.Sockets.Socket([System.Net.Sockets.AddressFamily]::InterNetwork,[System.Net.Sockets.SocketType]::Dgram,[System.Net.Sockets.ProtocolType]::UDP);$s.Connect((New
鸿鹄实验室
2021/04/15
1.8K0
powershell使用udp获取数据
分页解决方案 之 QuickPager的使用方法(URL分页、自动获取数据)
      适用范围:网站前台页面 等,从关系型数据库里提取数据,愿意使用Pager_SQL、DataAccessLibrary的情况。       优点:使用URL的方式,对于SEO比较友好。       缺点:保留查询状态没有太好的办法,GO的功能没有实现,有空看看别人是怎么做的。       Demo下载:http://www.cnblogs.com/jyk/archive/2008/07/29/1255891.html       使用方法: using JYK.Data; using JYK.C
用户1174620
2018/02/26
9190
如何获取Go最新动态和使用最新特性
热爱Go语言,一直使用着、关注着。那么如何获取Go最新动态,使用它最新的特性能? 1、获取最新动态 获取Go语言的最新动态有以下几种方法。 1.1 最直接最原始的方式 —— 官方源码库(hg clone https://code.google.com/p/go/),即 tip。关注Go开发者们提交代码的注释、代码diff。 1.2 关注 golang-dev 讨论组。Go开发者会在这上面讨论Go语言的开发 1.3 关注 issues,以及代码review 1.4 通过 Go dashboard 了解 Go
李海彬
2018/03/21
2.1K0
Android 9.0使用WebView加载Url时,显示页面无法加载
最近使用WebView加载Url显示页面,因为之前已经使用过很多次这种方式了,打包后在6.0的测试机上测试没什么问题,然后安心的将包给测试,测试大佬的手机系统是Android 9.0的,所以就出现了页面无法加载的情况,还以为是自己代码哪里写错了,检查了很多遍都没发现什么问题,然后在5.0,7.0,8.0的测试机上测试都没问题,那就想到是9.0系统问题了,先看页面报错图:
SoullessCoder
2019/08/07
7.4K0
Android 9.0使用WebView加载Url时,显示页面无法加载
使用js获取url中的get参数并转成json格式
写在前面的 没啥说的 上代码 思路就是先获取到?后面的参数区,然后 利用字符串转数组方法获取到各个参数 var json = {}; var url = 'https://www.ba
Theone67
2019/11/21
6.4K0

相似问题

Next.js无法使用动态图像url

122

使用getStaticProps()在next.js中获取未定义数据

11

使用Next.js动态url停止热重新加载

129

使用不同URL的Next.js动态路由

116

使用Sequelize动态获取数据库URL

121
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文