!
也想出现在这里? 联系我们
广告位
当前位置:首页>开发>其他开发实例>nuxt处理用户登录状态持久化

nuxt处理用户登录状态持久化

vue-cli项目中,我们可以用vuex-persistedstate,它可以使vuex的状态持久化,页面刷新都不会丢失,原理当然是localStorage啦!当然我更喜欢用vue-cookies进行保存token,问题来了,nuxt项目怎么保存登录状态呢?当然上面这两种方法我们都可以使用,但是有个问题,由于在created钩子中不存在window对象(获取cookie、localStorage都需要window对象),当你需要判断是否存在token的时候,你必须要在mounted进行操作,这说明页面进来的一瞬间你无法得知是否已经登录了,这会导致显示用户名、组件显示于隐藏都慢半拍

nuxt非常友好,它提供了fetch钩子,还有nuxtServerInit,这两个钩子都运行在服务端并且我们能很快速地操作store

一:fetch的使用

如果页面组件设置了fetch方法,它会在组件每次加载前被调用(在服务端或切换至目标路由之前),此方法需要跟服务端的人员配合

<script>
export default {
  async fetch ({ app, store, params }) {
    let { data } = app.$axios.get('/token');
    store.commit('setToken', data.token);
  }
}
</script>

二:nuxtServerInit的使用

终极无敌方法

import cookieparse from '~/assets/js/cookieparse.js';

export const state = () => ({
  token: ""
})

export const mutations = {
  changeToken: function(state, token){
    state.token = token;
  }
}

export const actions = {
  nuxtServerInit({commit}, {req}) {
    let cookie = req.headers.cookie;
    // 将cookie转成json对象
    let token = cookieparse('token', req);
    commit('changeToken', token?token:"");
  } 
}          

cookieparse.js

export default (cname, req) => {
  let name = cname + "="
  let decodedCookie
  if (typeof window === 'undefined') decodedCookie = decodeURIComponent(req.headers.cookie)
  else decodedCookie = decodeURIComponent(document.cookie)
  let ca = decodedCookie.split(';')
  for (let i = 0; i < ca.length; i++) {
    let c = ca[i]
    while (c.charAt(0) == ' ') {
      c = c.substring(1)
    }
    if (c.indexOf(name) == 0) {
      return c.substring(name.length, c.length)
    }
  }
  return ""
}

给TA打赏
共{{data.count}}人
人已打赏
其他开发实例

nuxt.js添加统计代码

2022-10-6 20:40:31

其他开发实例

LocalStorage与Cookie的异同

2022-10-6 20:41:13

声明 本站上的部份代码及教程来源于互联网,仅供网友学习交流,若您喜欢本文可附上原文链接随意转载。无意侵害您的权益,请发送邮件至 [email protected] 或点击右侧 私信:林沐阳 反馈,我们将尽快处理。
{{yiyan[0].hitokoto}}
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索