Vue3 + ts 使用 Vuex.Store 保存 token

1. 创建一个 store.ts

// store.ts
import { InjectionKey } from 'vue'
import { createStore, Store } from 'vuex'

// 为 store state 声明类型
export interface State {
  token: string
}

// 定义 injection key
export const key: InjectionKey<Store<State>> = Symbol()

export const store = createStore<State>({
  state: {
    token : '1222'
  },
  mutations: {
    increment (state, value) {
      // 变更状态
      state.token = value
    }
  }
})

2. 全局注册 store

import {createApp} from 'vue'
import App from './App.vue'
import * as VueRouter from 'vue-router';
import routes from "./config/route";
import Vant from 'vant';
import 'vant/lib/index.css';
import '../global.css';
import { store, key } from './store'

const app = createApp(App);
app.use(Vant);

const router = VueRouter.createRouter({
    // 内部提供了 history 模式的实现。为了简单起见,我们在这里使用 hash 模式。
    history: VueRouter.createWebHistory(),
    routes, // `routes: routes` 的缩写
})

app.use(store, key);

app.use(router);
app.mount('#app');

3. 将登录成功之后的 token 保存到 store

<script setup lang="ts">
import {useRoute, useRouter} from "vue-router";
import {ref} from "vue";
import myAxios from "../plugins/myAxios";
import {Toast} from "vant";
import {mapMutations, mapState} from 'vuex';
import { useStore } from 'vuex'
import { store, key } from '../store/index'


const sendCode = async () => {
  const res = await myAxios.post('/user/code?phone='+phone.value, {
    
  })
  console.log(res, '发送验证码');
  if (res.success && res.data) {
    Toast.success('验证码成功');
  
  } else {
    Toast.fail(res.errorMsg);
  }
};


const onSubmit = async () => {
  const res = await myAxios.post('/user/login', {
    phone: phone.value,
    code: code.value,
  })
  console.log(res, '用户登录');
 

  if (res.data.success) {
    Toast.success('登录成功');

    const token = res.data.data;
    console.log("token = " + token)

    // 保存token到Vuex store中
    store.commit('increment', token);
    

  } else {
    Toast.fail(res.data.errorMsg);
  }
};


</script>

4. 请求拦截加上 token

myAxios.interceptors.response.use(
  function(response) {
  
    if(response.data.code === 401) {
        // 无权限,跳回登录页面
        const redirectUrl = window.location.href;
        window.location.href = '/user/login?redirect=${redirectUrl}'
    }
    return response;
  },
  function(error) {
    // Do something with response error
    console.info(error)
    console.info(error.response.status)
    if(error.response.status === 401) {
        // 无权限,跳回登录页面
        const redirectUrl = window.location.href;
        window.location.href = '/user/login?redirect=${redirectUrl}'
    }
    return Promise.reject(error);
  }
);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3中使用Vuex时,可以借助辅助函数进行封装。你可以参考中提到的深入Vue3 TypeScript技术栈-coderwhy大神新课视频学习来改写你的代码。具体的目录结构可以按照以下方式进行组织: 在index.ts文件中,引入以下辅助函数: ``` import { useGetters } from './useGetters' import { useMutations } from './useMutations' import { useState } from './useState' import { useActions } from './useActions' export { useGetters, useState, useMutations, useActions } ``` 在使用Vuex的地方,你可以参考中给出的示例代码进行修改。在Vue2中,我们使用`...mapState`、`...mapGetters`、`...mapMutations`和`...mapActions`进行映射。在Vue3中,可以通过使用自定义的辅助函数来代替。 对于ts方面的变化,你需要做以下两个改变: 1. 在导入`useStore`时,需要修改为`import { useStore } from '../store'`,具体路径根据你的项目结构来确定。 2. 在定义自己的`useStore`组合式函数时,需要修改为`export function useStore () { return baseUseStore(key) }`,其中`key`可以按照你自己的需求进行导出。 此外,你还需要根据你的具体需求来修改`createStore`中的状态、getters、mutations和actions等。 以上是关于在Vue3中使用Vuex的一些变化和调整,请根据你的具体情况进行相应的修改。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue3+ts 使用 vuex辅助函数(mapState,mapMutations,mapGetters,mapActions) 对函数进行二次封装](https://blog.csdn.net/weixin_43245095/article/details/123380948)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *3* [vue3+Ts使用vuex模块化和非模块化管理的2种方式(非pinia)](https://blog.csdn.net/weixin_45441173/article/details/128510971)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值