成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Vue登錄注冊(cè),并保持登錄狀態(tài)

amuqiao / 2827人閱讀

摘要:關(guān)于登錄注冊(cè),并保持登錄狀態(tài),是玩家必經(jīng)之路,網(wǎng)上也有很多的解決方法,但是有一些太過(guò)于復(fù)雜,新手可能會(huì)看的一臉懵逼,現(xiàn)在給大家介紹一種我自己寫(xiě)項(xiàng)目在用而且并不難理解的一種方法。

關(guān)于vue登錄注冊(cè),并保持登錄狀態(tài),是vue玩家必經(jīng)之路,網(wǎng)上也有很多的解決方法,但是有一些太過(guò)于復(fù)雜,新手可能會(huì)看的一臉懵逼,現(xiàn)在給大家介紹一種我自己寫(xiě)項(xiàng)目在用而且并不難理解的一種方法。

項(xiàng)目中有一些路由是需要登錄才可以進(jìn)入的,比如首頁(yè),個(gè)人中心等等
有一些路由是不需要登錄就可以進(jìn)入,比如登錄頁(yè),注冊(cè)頁(yè),忘記密碼等等
那如何判斷路由是否需要登錄呢?就要在路由JS里面做文章

在router.js中添加meta區(qū)分

比如登錄注冊(cè)頁(yè)面,不需要登錄即可進(jìn)入,那么我們把meta中的isLogin標(biāo)志設(shè)置為false

{
  //登錄
  path: "/login",
  component: login,
  meta: {
    isLogin: false
  }
},
{
  //注冊(cè)
  path: "/register",
  component: register,
  meta: {
    isLogin: false
  }
},

而在首頁(yè)我們需要登錄才能進(jìn)入,那么我們把meta中的isLogin標(biāo)志設(shè)置為true

{
  //首頁(yè)
  path: "/home",
  component: home,
  meta: {
    isLogin: true
  },
}

這樣我們就為進(jìn)入各個(gè)路由是否需要登錄做了區(qū)分。

接下來(lái)我們?cè)趌ogin.vue中修改登錄后狀態(tài)

我們使用axios向后臺(tái)發(fā)起登錄請(qǐng)求

this.$axios.post("/xxx/login", {user:name,password:pwd})
    .then(data => {
        //登錄失敗,先不討論
        if (data.data.status != 200) {
          //iViewUi的友好提示
          this.$Message.error(data.data.message);
        //登錄成功
        } else {
          //設(shè)置Vuex登錄標(biāo)志為true,默認(rèn)userLogin為false
          this.$store.dispatch("userLogin", true);
          //Vuex在用戶刷新的時(shí)候userLogin會(huì)回到默認(rèn)值false,所以我們需要用到HTML5儲(chǔ)存
          //我們?cè)O(shè)置一個(gè)名為Flag,值為isLogin的字段,作用是如果Flag有值且為isLogin的時(shí)候,證明用戶已經(jīng)登錄了。
          localStorage.setItem("Flag", "isLogin");
          //iViewUi的友好提示
          this.$Message.success(data.data.message);
          //登錄成功后跳轉(zhuǎn)到指定頁(yè)面
          this.$router.push("/home");
        }
 });

Vuex里面我是這樣寫(xiě)的(如果項(xiàng)目不需要Vuex,那么直接使用HTML5儲(chǔ)存就可以了):

export const store = new Vuex.Store({
  // 設(shè)置屬性
  state: {
    isLogin: false,
  },

  // 獲取屬性的狀態(tài)
  getters: {
    //獲取登錄狀態(tài)
    isLogin: state => state.isLogin,
  },

  // 設(shè)置屬性狀態(tài)
  mutations: {
    //保存登錄狀態(tài)
    userStatus(state, flag) {
      state.isLogin = flag
    },
  },

  // 應(yīng)用mutations
  actions: {
    //獲取登錄狀態(tài)
    userLogin({commit}, flag) {
      commit("userStatus", flag)
    },
  }
})
重點(diǎn)來(lái)了~,在mian.js里
router.beforeEach((to, from, next) => {

  //獲取用戶登錄成功后儲(chǔ)存的登錄標(biāo)志
  let getFlag = localStorage.getItem("Flag");

  //如果登錄標(biāo)志存在且為isLogin,即用戶已登錄
  if(getFlag === "isLogin"){

    //設(shè)置vuex登錄狀態(tài)為已登錄
    store.state.isLogin = true
    next()

    //如果已登錄,還想想進(jìn)入登錄注冊(cè)界面,則定向回首頁(yè)
    if (!to.meta.isLogin) {
       //iViewUi友好提示
      iView.Message.error("請(qǐng)先退出登錄")
      next({
        path: "/home"
      })
    }
  
  //如果登錄標(biāo)志不存在,即未登錄
  }else{

    //用戶想進(jìn)入需要登錄的頁(yè)面,則定向回登錄界面
    if(to.meta.isLogin){
      next({
        path: "/login",
      })
      //iViewUi友好提示
      iView.Message.info("請(qǐng)先登錄")
    //用戶進(jìn)入無(wú)需登錄的界面,則跳轉(zhuǎn)繼續(xù)
    }else{
      next()
    }

  }

});

router.afterEach(route => {
  window.scroll(0, 0);
});

這樣就已經(jīng)完成了Vue的登錄注冊(cè),當(dāng)用戶關(guān)閉瀏覽器或者第二天再次進(jìn)入網(wǎng)站,用戶依舊可以保持著登錄的狀態(tài)直到用戶手動(dòng)退出登錄。

Tips:用戶退出只需要localStorage.removeItem("Flag")即可

如果有什么疑問(wèn)歡迎留言,有錯(cuò)誤或者有更簡(jiǎn)單的方法歡迎大力指出~~

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/108270.html

相關(guān)文章

  • 這兩天老是有兄弟問(wèn)到Vue的登陸和注冊(cè),登陸成功留在首頁(yè),沒(méi)有登錄回到登錄頁(yè)面,現(xiàn)在我用最簡(jiǎn)單實(shí)用的

    摘要:其實(shí)登錄注冊(cè),并且登錄一次保持登錄的狀態(tài),是每個(gè)項(xiàng)目都需要實(shí)現(xiàn)的功能。 其實(shí)登錄注冊(cè),并且登錄一次保持登錄的狀態(tài),是每個(gè)項(xiàng)目都需要實(shí)現(xiàn)的功能。 網(wǎng)上也有很多的方法,不過(guò),不是通俗易懂,在這里說(shuō)一下我自己的方法,非常簡(jiǎn)單實(shí)用核心就是用localStorage存、取數(shù)據(jù),這樣當(dāng)刷新瀏覽器,或者關(guān)閉在打開(kāi)的時(shí)候能達(dá)到預(yù)期想要的效果 在router/index.js中 import Vue ...

    gplane 評(píng)論0 收藏0
  • 這兩天老是有兄弟問(wèn)到Vue的登陸和注冊(cè),登陸成功留在首頁(yè),沒(méi)有登錄回到登錄頁(yè)面,現(xiàn)在我用最簡(jiǎn)單實(shí)用的

    摘要:其實(shí)登錄注冊(cè),并且登錄一次保持登錄的狀態(tài),是每個(gè)項(xiàng)目都需要實(shí)現(xiàn)的功能。 其實(shí)登錄注冊(cè),并且登錄一次保持登錄的狀態(tài),是每個(gè)項(xiàng)目都需要實(shí)現(xiàn)的功能。 網(wǎng)上也有很多的方法,不過(guò),不是通俗易懂,在這里說(shuō)一下我自己的方法,非常簡(jiǎn)單實(shí)用核心就是用localStorage存、取數(shù)據(jù),這樣當(dāng)刷新瀏覽器,或者關(guān)閉在打開(kāi)的時(shí)候能達(dá)到預(yù)期想要的效果 在router/index.js中 import Vue ...

    paraller 評(píng)論0 收藏0
  • Vue中的驗(yàn)證登錄狀態(tài)

    摘要:用存儲(chǔ)用戶路由守衛(wèi)路由中設(shè)置的字段就在當(dāng)中每次跳轉(zhuǎn)的路徑登錄狀態(tài)下訪問(wèn)頁(yè)面會(huì)跳到如果沒(méi)有訪問(wèn)任何頁(yè)面。一個(gè)簡(jiǎn)單的保存登錄狀態(tài)的小。 Vue項(xiàng)目中實(shí)現(xiàn)用戶登錄及token驗(yàn)證 先說(shuō)一下我的實(shí)現(xiàn)步驟: 使用easy-mock新建登錄接口,模擬用戶數(shù)據(jù) 使用axios請(qǐng)求登錄接口,匹配賬號(hào)和密碼 賬號(hào)密碼驗(yàn)證后, 拿到token,將token存儲(chǔ)到sessionStorage中,并跳轉(zhuǎn)到首...

    draveness 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

amuqiao

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<