Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >在NextJS中获取客户端和服务器端的数据

在NextJS中获取客户端和服务器端的数据
EN

Stack Overflow用户
提问于 2021-08-29 03:39:59
回答 3查看 1.6K关注 0票数 0

我需要在NextJS项目中的一些组件中使用第三方API获取数据。

我希望服务器使用SEO的API预呈现组件。但在此之后,当用户与应用程序交互时,组件道具应该在客户端获取。

我能够通过使用NextJS getInitialProps方法来实现这个行为。但是在官方的NextJS文档中,建议使用getStaticPropsgetServerSideProps

我想知道做这件事的推荐方法是什么。

EN

回答 3

Stack Overflow用户

发布于 2021-08-29 04:03:44

当我们使用getServerSideProps而不是getInitialProps作为getServerSideProps在服务器上而不是浏览器上执行代码时,包的大小会更小。

阅读更多关于这两种这里之间的区别的文章。

票数 1
EN

Stack Overflow用户

发布于 2021-08-29 15:42:36

Next.js docs 他说

如果您使用的是Next.js 9.3或更高版本,我们建议您使用getStaticProps或getServerSideProps而不是getInitialProps。 这些新的数据获取方法允许您在静态生成和服务器端呈现之间进行粒度选择。了解有关页面和数据获取的文档的更多信息。

如果以下情况下,您应该使用getStaticProps:

  • 呈现页面所需的数据在用户请求之前的构建时可用。
  • 这些数据来自无头CMS。
  • 数据可以公开缓存(不特定于用户)。
  • 页面必须预先呈现(对于SEO)并且非常快- getStaticProps生成HTML文件,这两个文件都可以由CDN缓存以提高性能。

我什么时候应该使用getServerSideProps?只有当您需要预呈现一个必须在请求时获取其数据的页面时,才应该使用getServerSideProps。到第一个字节的时间(TTFB)将比getStaticProps慢,因为服务器必须在每个请求中计算结果,并且在没有额外配置的情况下,CDN无法缓存结果。

如果不需要预呈现数据,那么应该考虑在客户端获取数据。点击这里到了解更多

票数 0
EN

Stack Overflow用户

发布于 2021-12-13 01:25:35

如果您已经知道您的网站将包含多少页,那么使用静态站点生成,即使用getStaticProps。这将在构建过程中预先生成所有页面.

示例是一个投资组合网站,其内容大多是静态的。

注意到:-使用getStaticProps,对您的网站所做的任何更改都不会被反映出来,您需要重新部署才能看到更改。

因此,如果您的投资组合还包含一个博客,那么getStaticProps将不是一个理想的解决方案,相反,您可以通过在getStaticProps函数中添加一个重新验证键来使用增量静态再生,这意味着在每个请求上最多每X秒重新生成页面。

现在,如果您需要对每个请求进行预渲染,或者您需要访问请求对象,例如设置cookie,那么服务器端呈现是一个选项,使用getServerSideProps函数。getServerSideProps仅在服务器上运行,而在构建过程中不运行

对于客户端数据获取,您可以使用下一个JS提供的useEffect钩子或swr钩子。

因此,在您的情况下,如果您使用客户端数据获取,那么使用getServerSideProps可能没有任何意义,除非您需要该请求响应对象。

因此,您可以将获取的客户端数据与getStaticProps结合起来(很可能是使用重新验证键)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68972525

复制
相关文章
访问令牌JWT
By reference token(透明令牌),随机生成的字符串标识符,无法简单猜测授权服务器如何颁 发和存储资源服务器必须通过后端渠道,发送回OAuth2授权服务器的令牌检查端点,才能校验令牌 是否有效,并获取claims/scopes等额外信息
乐心湖
2020/08/02
1.7K0
GitLab 冷知识:在 Gitlab CI Pipeline 中进行 Git Push 操作 🦊
在日常工作中,经常会遇到这样一种场景:需要在 GItLab CI Job 中进行 Git Push 操作,将修改或构建好的代码推送到远端 Git 代码仓库当中。这是一个十分常见操作,本篇文章将会提供一个最简单且实用的方法来实现这个场景,希望对您有所帮助。
郭旭东
2022/12/05
5.5K0
GitLab 冷知识:在 Gitlab CI Pipeline 中进行 Git Push 操作 🦊
Gitlab CI 在 Kubernetes 中的 Docker 缓存
前面我们有文章介绍过如何在 Kubernetes 集群中使用 GitLab CI 来实现 CI/CD,在构建镜像的环节我们基本上都是使用的 Docker On Docker 的模式,这是因为 Kubernetes 集群使用的是 Docker 这种容器运行时,所以我们可以将宿主机的 docker.sock 文件挂载到容器中构建镜像,而最近我们在使用 Kubernetes 1.22.X 版本后将容器运行时更改为了 Containerd,这样节点上没有可用的 Docker 服务了,这个时候就需要更改构建镜像的模式了,当然要实现构建镜像的方式有很多,我们这里还是选择使用 Docker 来构建我们的 Docker 镜像,也就是使用 Docker IN Docker 的模式。
我是阳明
2021/11/17
1.5K0
在 Gitlab CI 中调用 Sonarqube 进行代码扫描
Gitlab 提供了基于 Code Climate 的代码质量评估功能,这一功能是通过 dind(Docker in Docker)方式运行的,在 Kubernetes 环境中、尤其是托管集群中,这种方式不太合适,还好还有一个替代方案:Sonarqube,通过在 .gitlab-ci.yml 中的设置,可以使用 Sonarqube 对代码进行扫描,接收到 Commit 之后,Sonarqube 会生成针对提交的代码质量提示,如图所示:
崔秀龙
2019/07/22
8.1K0
在 Gitlab CI 中调用 Sonarqube 进行代码扫描
Gitlab - 安装的社区版 Gitlab-ce,解决访问网页报502-Whoops, GitLab is taking too much time to respond的问题
在自己虚拟机(centos7)上装了 Gitlab-ce,就是社区版的 Gitlab,版本是 13.0+
小菠萝测试笔记
2021/04/25
5.2K0
Gitlab - 安装的社区版 Gitlab-ce,解决访问网页报502-Whoops, GitLab is taking too much time to respond的问题
持续集成gitlab-ci.yml配置文档基础
[TOC] 0x00 简述 Q:什么是.gitlab-ci.yaml?它有什么作用? 答:gitlab-ci全称是gitlab continuous integration的意思就是持续集成;gitl
全栈工程师修炼指南
2020/10/23
15K1
持续集成gitlab-ci.yml配置文档基础
面向个人开发者应该打造的CICD部署系统
作为一个个人开发者,在业余时间也会想着开发一些个人的好玩的项目,去开发一些效率工具,开发一些自己喜欢的程序,在这个前提下,很多人购买了自己的服务器,作为一个前端开发,在最开始的时候对服务器相对会比较陌生,如果接触不多,在部署自己的项目过程中也会有许许多多的不便,我们也可以为自己搭建一套自动化部署,能够让我们在开发个人项目的时候享受同样的便捷。
Snine
2022/09/28
1.4K0
面向个人开发者应该打造的CICD部署系统
持续集成gitlab-ci.yml配置文档基础
[TOC] 0x00 简述 Q:什么是.gitlab-ci.yaml?它有什么作用? 答:gitlab-ci全称是gitlab continuous integration的意思就是持续集成;gitl
全栈工程师修炼指南
2022/09/29
12.2K0
持续集成gitlab-ci.yml配置文档基础
gitlab配置https方式访问
前提:gitlab我安装的版本是13.*,已可以通过域名访问。 mkdir /etc/gitlab/ssl cp server.crt server.key /etc/gitlab/ssl vim /etc/gitlab/gitlab.rb 修改内容如下: nginx['ssl_certificate'] = "/etc/gitlab/ssl/ebyh.crt" nginx['ssl_certificate_key'] = "/etc/gitlab/ssl/ebyh.key" external_ur
休辞醉倒
2019/07/25
4.6K0
访问令牌过期后,如何自动续期?
JWT是JSON Web Token的缩写,是为了在网络应用环境间传递声明而执行的- -种基于JSON的开放标准((RFC 7519)。JWT本身没有定义任何技术实现,它只是定义了一种基于Token的会话管理的规则,涵盖Token需要包含的标准内容和Token的生成过程,特别适用于分布式站点的单点登录(SSO) 场景。
Tinywan
2023/03/08
2.7K0
访问令牌过期后,如何自动续期?
多分支流水线任务对 GitLab SCM 的支持
这个插件还没有二进制文件可用,因为这个插件还处于非常早期的 alpha 阶段,还没有为公众准备好。如果您想尽早介入,可以尝试自己从源代码构建它。
LinuxSuRen
2019/07/15
1.8K0
多分支流水线任务对 GitLab SCM 的支持
XXL-JOB访问令牌(AccessToken)设置
为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯;
Li_XiaoJin
2022/12/28
20.8K0
XXL-JOB访问令牌(AccessToken)设置
C/C++ 实现提升访问令牌权限
在我们编程实现一些系统操作的时候,往往要求我们执行操作的进程拥有足够的权限方可成功操作。比如,我们使用 ExitWindows 函数实现关机或重启操作的时候,就要求我们的进程要有 SE_SHUTDOWN_NAME 的权限,否则,会忽视不执行操作。这时,我们唯一能够做的,就是按照要求,提升我们进程的权限。
微软技术分享
2022/12/28
7900
gitlab访问限制问题------Forbidden
重启-gitlab:       gitlab-ctl restart          
Wyc
2018/09/11
2.5K0
Spring Security的项目中集成JWT Token令牌安全访问后台API
最近接了一个私活项目,后台使用的是Spring Boot脚手架搭建的,认证和鉴权框架用的Spring Security。同时为了确保客户端安全访问后台服务的API,需要用户登录成功之后返回一个包含登录用户信息的jwt token, 用于调用其他接口时将此jwt token携带在请求头中作为调用者的认证信息。最近一个多月一方面在忙着做这个项目,另一方面恰好遇上了精彩的世界杯,也没怎么发文了。很多时候真的深感写篇原创文章比单纯的敲代码麻烦多了,但是好久不更文还是要检讨一下自己的惰性,客服自身的惰性是每个想要突破自我、不甘平庸的普通人的一辈子都不能松懈的重任。
用户3587585
2023/03/09
4.3K0
Spring Security的项目中集成JWT Token令牌安全访问后台API
Ubuntu上如何使用GitLab CI搭建持续集成Pipeline
GitLab Community Edition是一个自托管的Git存储库提供程序,具有帮助项目管理和软件开发的附加功能。GitLab提供的最有价值的功能之一是内置的持续集成和交付工具GitLab CI。
爆栈工程师
2018/08/13
3.9K0
Ubuntu上如何使用GitLab CI搭建持续集成Pipeline
从外部访问Kubernetes中的Pod
本文主要讲解访问kubernetes中的Pod和Serivce的几种方式,包括如下几种:
我的小碗汤
2019/07/30
2.9K0
安装 GitLab CE
DevOps 理念落实得最为彻底的一类案例就是 CI/CD(持续集成/持续交付) 系统
franket
2021/08/12
3.6K0
使用GitLabCI实现monorepos项目CI/CD
基于现代Web的应用程序通常都包含多种服务。例如,后端API和前端客户端。在规模扩大成为问题的大型项目中,服务也可以拆分为多个微服务。如何在这样的项目中组织源代码?一种解决方案是monorepo,即项目中所有源代码在同一个存储库中管理。还有一种是每个微服务分别创建一个存储库管理。
DevOps云学堂
2020/06/19
9.5K0
GitLab 简明维护指南(v2020.05)
本文使用「署名 4.0 国际 (CC BY 4.0)」许可协议,欢迎转载、或重新修改使用,但需要注明来源。 署名 4.0 国际 (CC BY 4.0)
soulteary
2020/05/05
6550
GitLab 简明维护指南(v2020.05)

相似问题

如何从TinyMCE编辑器中获取字数统计?

13

如何在ck编辑器中输入文本时显示字数统计

123

在文本编辑器中显示XML (例如,tinymce,Jquery编辑器) PHP

10

在TinyMCE编辑器中显示视频

1109

如何在tinyMCE编辑器中显示RTF文本

113
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

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

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文