欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項(xiàng)目退出登錄清除store數(shù)據(jù)的三種方法

 更新時(shí)間:2022年09月22日 09:35:44   作者:IT博客技術(shù)分享  
最近使用vue做用戶的登錄/退出,在開(kāi)發(fā)過(guò)程中遇到的一些問(wèn)題,記錄下來(lái),下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目退出登錄清除store數(shù)據(jù)的三種方法,需要的朋友可以參考下

方法一:(不友好,頁(yè)面會(huì)白屏,不推薦使用)

在退出登錄的loginOut 方法里面:

window.location.reload()

方法二 : (不會(huì)出現(xiàn)白屏,推薦使用)

利用v-if控制router-view,在根組件APP.vue中實(shí)現(xiàn)一個(gè)刷新方法

<template>
    <router-view v-if="isRouterAlive"/>     //路由的組件
</template>
<script>
export default {
 data () {
   return {
     isRouterAlive: true
   }
 },
 methods: {
   reload () {
     this.isRouterAlive = false
     this.$nextTick(() => (this.isRouterAlive = true))
   }   
 }
}
</script>

然后使用的時(shí)候調(diào)用: this.reload() 方法

方法三 : vuex清除token (不會(huì)出現(xiàn)白屏,推薦使用)

 vuex清除token

由于項(xiàng)目中需要一個(gè)用戶登出的功能,而數(shù)據(jù)放在Vuex中在登出沒(méi)有刷新時(shí)數(shù)據(jù)并不會(huì)更新

所以找到了這樣一個(gè)很不錯(cuò)的方法

將state以各種方式保存

注冊(cè)時(shí)調(diào)用函數(shù)賦值

清空時(shí)再將保存的state賦值替換當(dāng)前的state

over

1. 首先默認(rèn)state時(shí)要用新的方法注冊(cè)

把數(shù)據(jù)寫(xiě)在函數(shù)的返回值中(其他方法也可以只要能調(diào)用)

const getDefaultState = () => {
  return {
    token: getToken(),
    name: '',
    avatar: '',
    permList:[]
  }
}

 2. 給Vuex中的state賦值并注冊(cè)

const state = getDefaultState();
 
const store = new Vuex.Store({
  modules: {
    app,
    settings,
    state,
    permissions
  },
  getters
})

 3. 在mutations中定義方法

  RESET_STATE: (state) => {
    Object.assign(state, getDefaultState())
  },

 4. 頁(yè)面中使用

    commit('RESET_STATE');

5. 全部完整代碼如下:

 
const getDefaultState = () => {
  return {
    token: getToken(),
    name: '',
    avatar: ''
  }
}
 
const state = getDefaultState()
 
const mutations = {
  RESET_STATE: (state) => {
    Object.assign(state, getDefaultState())
  },
}
 
 logout({ commit, state }) {
    return new Promise((resolve, reject) => {
      logout(state.token).then(() => {
        removeToken() // must remove  token  first
        resetRouter()
        commit('RESET_STATE')
        resolve()
      }).catch(error => {
        reject(error)
      })
    })
  },

6. 退出登錄

組件中派發(fā)任務(wù)

    async logout() {
      await this.$store.dispatch("user/logout");
      this.$router.push(`/login?redirect=${this.$route.fullPath}`);
    },
  },

親自測(cè)試有效:

第三種方法強(qiáng)烈推薦使用。

總結(jié)

到此這篇關(guān)于vue項(xiàng)目退出登錄清除store數(shù)據(jù)的三種方法的文章就介紹到這了,更多相關(guān)vue退出登錄清除store數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue全局實(shí)現(xiàn)數(shù)字千位分隔符格式

    vue全局實(shí)現(xiàn)數(shù)字千位分隔符格式

    這篇文章主要為大家詳細(xì)介紹了vue全局實(shí)現(xiàn)數(shù)字千位分隔符格式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue-cropper組件實(shí)現(xiàn)圖片切割上傳

    vue-cropper組件實(shí)現(xiàn)圖片切割上傳

    這篇文章主要為大家詳細(xì)介紹了vue-cropper組件實(shí)現(xiàn)圖片切割上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • 深入探究Vue2響應(yīng)式原理的實(shí)現(xiàn)及存在的缺陷

    深入探究Vue2響應(yīng)式原理的實(shí)現(xiàn)及存在的缺陷

    Vue的響應(yīng)式數(shù)據(jù)機(jī)制是其核心特性之一,它能夠自動(dòng)追蹤數(shù)據(jù)的變化,并實(shí)時(shí)更新相關(guān)的視圖,然而,Vue2中的響應(yīng)式數(shù)據(jù)機(jī)制并非完美無(wú)缺,本文將探討Vue2響應(yīng)式原理及其存在的缺陷
    2023-08-08
  • vue2使用ts?vue-class-component的過(guò)程

    vue2使用ts?vue-class-component的過(guò)程

    vue-property-decorator?是一個(gè)?Vue.js?的裝飾器庫(kù),它提供了一些裝飾器來(lái)讓你在?Vue?組件中定義屬性、計(jì)算屬性、方法、事件等,本文給大家介紹vue2使用ts?vue-class-component的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2023-11-11
  • vue-router-link選擇樣式設(shè)置方式

    vue-router-link選擇樣式設(shè)置方式

    這篇文章主要介紹了vue-router-link選擇樣式設(shè)置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue+elementUI中使用Echarts之餅圖問(wèn)題

    vue+elementUI中使用Echarts之餅圖問(wèn)題

    這篇文章主要介紹了vue+elementUI中使用Echarts之餅圖問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 在vue中利用全局路由鉤子給url統(tǒng)一添加公共參數(shù)的例子

    在vue中利用全局路由鉤子給url統(tǒng)一添加公共參數(shù)的例子

    今天小編就為大家分享一篇在vue中利用全局路由鉤子給url統(tǒng)一添加公共參數(shù)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • Vue組件化學(xué)習(xí)之scoped詳解

    Vue組件化學(xué)習(xí)之scoped詳解

    這篇文章主要為大家詳細(xì)介紹了Vue組件化學(xué)習(xí)之scoped,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • 代號(hào)為Naruto的Vue?2.7正式發(fā)布功能詳解

    代號(hào)為Naruto的Vue?2.7正式發(fā)布功能詳解

    這篇文章主要為大家介紹了代號(hào)為Naruto的Vue?2.7正式發(fā)布功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 查看當(dāng)前vue項(xiàng)目所需Node.js版本的方法

    查看當(dāng)前vue項(xiàng)目所需Node.js版本的方法

    這篇文章主要大家介紹了查看當(dāng)前vue項(xiàng)目所需Node.js版本的方法,文章通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-11-11

最新評(píng)論