首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >next-auth中useSession()的“加载”返回值是什么?

next-auth中useSession()的“加载”返回值是什么?
EN

Stack Overflow用户
提问于 2020-07-08 23:46:28
回答 1查看 5.9K关注 0票数 9

我正在编写一个Next.js项目,并使用GitHub和next-auth实现身份验证。在next-auth的例子中,有一个对useSession()的调用,它返回两个对象:sessionloading。但是,我所看到的示例中没有一个实际使用loading对象。

代码语言:javascript
复制
import React from 'react'
import { 
  useSession, 
  signin, 
  signout 
} from 'next-auth/client'

export default () => {
  const [ session, loading ] = useSession()

  return <p>
    {!session && <>
      Not signed in <br/>
      <button onClick={signin}>Sign in</button>
    </>}
    {session && <>
      Signed in as {session.user.email} <br/>
      <button onClick={signout}>Sign out</button>
    </>}
  </p>
}

问题loading的目的是什么?在实践中是如何使用的?

EN

回答 1

Stack Overflow用户

发布于 2020-07-31 12:24:45

loading选项指示正在更新会话状态;获取会话数据时是true,检查时是false

它稍微复杂一些,因为即使加载了session属性也可以填充它(例如,因为它已经有一个缓存的值可以从以前的调用中使用),所以技术上session可以被填充,即使loadingtrue

如果在NextAuth.js中使用pages/_app.js提供程序,如果在getInitialProps()getServerSideProps()中调用了getSession(),则还可以填充从useSession返回的session对象。

如果您有一个活动的会话,像窗口获取或丢失焦点这样的操作将导致NextAuth.js在后台再次检查会话状态,以确保它不会过时。

tl;dr

当您检查loading时,您可能还想首先检查session不是null。如果session状态是一个对象,则用户有一个有效的会话,您不需要等待loading返回。

但是,如果sessionnull,而loadingfalse,那么它们肯定没有活动会话。

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

https://stackoverflow.com/questions/62805282

复制
相关文章

相似问题

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