nextjs通过使用getServerSideProps实现登录后跳转上一页

在实际开发中,经常遇到登录后跳转到之前的页面,可使用getServerSideProps实现该功能,getServerSideProps 是 next.js 中的一项特色功能,可以让我们在给页面设置一些初始的 props 参数。

getServerSideProps 是定义在页面中的 API,但是其执行环境是 node 端,而不是客户端,一般常见使用场景为:

  • 页面前置权限校验
  • 页面必备参数获取

使用时需要在对应的 page 文件中 export getServerSideProps

复制代码
const Page = props => {
// 登录
  const login = async () => {
    const data = {
      account: mobile ? mobile : email,
      password: pwd,
      clientType: 2,  //客户端类型
      AreaCode: '+' + areaCode,
      ClientMark: guid(),
      Ip: ip
    }
    const re = /^\w+@[a-z0-9]+\.[a-z]{2,4}$/
    const myreg = /^\d+(.\d{1,2})?$/
    if (index == 1) {
      if (areaCode == '') {
        Toast.show({ content: lang['请选择国家'] })
        return
      }
      if (!myreg.test(mobile)) {
        Toast.show({ content: lang['手机号码输入错误'] })
        return
      }
    } else if (index == 2) {
      // if (!re.test(email)) {
      //   Toast.show({ content: lang['电子邮箱输入错误'] })
      //   return
      // }
    }
    const rep = await props.user.login(data)
    if (!rep.success) {
      Toast.show({ content: rep.error.message })
    } else {
      setToken(rep.result.token)
      setAreaCodeLang(areaCode)
      props.user.token = rep.result.token
      getUserInfo()
      setTimeout(() => {
        props.ws.reconnect()
        if (props.prevPageHeader.referer && pathname != '/login' ) {
          back()
        } else {
          push('/user')
        }
      }, 1000);
    }
  }
    return <div>page</div>;
};
export async function getServerSideProps(context) {
    return {
        props: {
        	prevPageHeader: context.req.headers,
        }
    };
}
export default Page;

这样便可以从页面组件中直接使用 props 来获取 getServerSideProps 注入的 props 了。上述代码就把context.req.headers注入了props中,可以通过context.req.headers中的referer获取到上一个页面的路由地址,从而实现登录后跳转到上一页。

注意:

  • 直接在地址栏中输入地址进行跳转的context.req.headers.referer会没有值。
  • 有些特殊页面,例如登录页登录的,上一页为登录页,所以不需要跳转到上一页,可以通过pathname ,判断是否是这些特殊页面而不进行跳转
  • getServerSideProps 只能在页面组件中使用,在其他子组件中是不能使用的。
  • 通过npm run export 打包发布的项目不能使用getServerSideProps

与 getStaticProps 只在build时生成一遍静态页面,或者定期重新生成页面不同,使用getServerSideProps,页面在每接收到一条传入请求就重新生成一遍。

因为每次请求都是从数据库读数据重新生成页面,页面加载速度会变慢。但是使用getServerSideProps 可以访问 request 对象。

如果页面不是需要每秒更新几次,或者需要访问 request 对象,那么使用getStaticProps 函数更好。
next官网 getServerSideProps的参数信息

或者参考:https://www.geeksforgeeks.org/next-js-getserversideprops-function/

相关推荐
远山无期2 分钟前
解决Tailwind任意值滥用:规范化CSS开发体验
前端·css·eslint
用户542778485154011 分钟前
Vue 3 中开发高阶组件(HOC)与 Renderless 组件
前端
幼儿园老大21 分钟前
告别代码屎山!UniApp + Vue3 自动化规范:ESLint 9+ 扁平化配置全指南
javascript·vue.js
HIT_Weston24 分钟前
67、【Ubuntu】【Hugo】搭建私人博客(一)
前端·ubuntu·hugo
阿里巴啦37 分钟前
用React+Three.js 做 3D Web版搭建三维交互场景:模型的可视化摆放与轻量交互
前端·react·three.js·模型可视化·web三维·web三维交互场景
Liu.7741 小时前
vue3组件之间传输数据
前端·javascript·vue.js
|晴 天|1 小时前
前端闭包:从概念到实战,解锁JavaScript高级技能
开发语言·前端·javascript
开发者小天1 小时前
react的拖拽组件库dnd-kit
前端·react.js·前端框架
用户4445543654261 小时前
在Android开发中阅读源码的指导思路
前端
用户54277848515401 小时前
ESM 模块(ECMAScript Module)详解
前端