IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue项目 用户登录状态持久存储 (即使刷新) -> 正文阅读

[JavaScript知识库]Vue项目 用户登录状态持久存储 (即使刷新)

本地存储 isLogin 登录状态 并保存到vuex

Header.vue

<div class="content-login-success" v-if="isLogin">
            <div style="cursor: pointer">我的课程</div>
            <div @mouseenter="isUserInfo = true">
              <!-- 用户头像 -->
              <img
                class="avator"
                :src="userInfo.avatar"
                alt=""
                v-if="userInfo.avatar"
              />
              <!-- 默认头像 -->
              <img class="avator" :src="avatarImg" alt="" v-else />
              <!-- 头像信息 -->
            </div>
</div>

import api from "../../common/api/auth";
import { mapState, mapMutations, mapActions } from "vuex";

computed: {
    //
    ...mapState({
      userInfo: (state) => state.user.userInfo,
      isLogin: (state) => state.user.isLogin,
    }),
  },

methods: {
    ...mapActions(["saveUserInfoAction", "saveLoginStatusAction"]),
    //账号密码登录 按钮
    submitPhoneForm(phoneFormRef) {
      this.$refs[phoneFormRef].validate((valid) => {
        if (!valid) return; //验证通过否
        if (valid) {
          //开启加载动画
          var phoneLoading = Loading.service({
            lock: true,
            text: "loading",
            spinner: "el-icon-loading",
            background: "rgba(0,0,0,0.7)",
          });
        }
        let username = Encrypt(this.phoneForm.username);
        let password = Encrypt(this.phoneForm.password);
        api
          .loginByJson({
            username,
            password,
          })
          .then((res) => {
            //console.log(res);
            if (res.meta.code === "10006") {
              //10006为登录成功
              let accessToken = res.data.accessToken;
              //本地存储
              localStorage.setItem("token", Encrypt(accessToken));
              localStorage.setItem("isLogin", JSON.stringify(true));
              //改变vuex中登录状态
              this.saveLoginStatusAction();
              console.log(this.isLogin);
              //调用获取用户信息的方法
              this.getUserInfo();
              this.$message({
                message: "登录成功,请去学习!",
                type: "success",
              });
              this.$router.go(0); //刷新当前页面
            } else {
              this.$message({
                message: res.meta.msg,
                type: "error",
              });
            }
            //关闭加载动画
            phoneLoading.close();
            this.loginDialog = false;
          })
          .catch((err) => {
            phoneLoading.close();
            this.$message({
              message: res.meta.msg,
              type: "error",
            });
          });
      });
    },
    //退出登录
    goLogout() {
      this.$confirm("您确认要退出登录吗", "提示信息", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          api
            .logOut()
            .then((res) => {
              this.$message({
                type: "success",
                message: "退出成功",
              });
              localStorage.removeItem("token");
              localStorage.removeItem("isLogin");
              this.saveLoginStatusAction(false);
              this.$router.push("/");
            })
            .catch((err) => {
              console.log(err);
            });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已经取消退出",
          });
          return;
        });
    }
  },

modules/user.js

export default {
  state: {
    userInfo: {
      avatar: '/image/common/avator.png',
      nickName: '默认昵称',
      gender: 1,
      city: '成都',
      id: 1
    },
    isLogin: JSON.parse(localStorage.getItem('isLogin')) || false//默认的登录状态
  },
  getters: {

  },
  mutations: {
    saveUserInfo(state, payLoad) {
      state.userInfo = payLoad
    },
    saveLoginStatus(state, payload) {
      state.isLogin = payload
    }
  },
  actions: {
    saveUserInfoAction({ commit }, payLoad) {
      commit('saveUserInfo', payLoad)
    },
    saveLoginStatusAction({ commit }, payLoad) {
      commit('saveLoginStatus', payLoad)
    }
  }
}

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-01 20:30:57  更:2022-02-01 20:31:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 15:00:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码