場(chǎng)景:vue-router實(shí)現(xiàn)的單頁應(yīng)用,登錄頁調(diào)用登錄接口后,服務(wù)器返回用戶信息,然后通過router.push({name: 'index', params: res.data})傳給主頁組件,并在主頁顯示數(shù)據(jù)。但是刷新頁面后,數(shù)據(jù)就消失了。

解決方案:

1、session&服務(wù)器渲染

傳統(tǒng)的方案是,登錄頁和主頁是單獨(dú)的兩個(gè)頁面,登錄成功后服務(wù)器生成用戶信息對(duì)應(yīng)的session,然后渲染主頁數(shù)據(jù),并通過響應(yīng)頭將sessionid傳給瀏覽器并生成相應(yīng)的cookie文件。這樣下次請(qǐng)求頁面時(shí),瀏覽器會(huì)在http header帶上相應(yīng)的cookie,然后服務(wù)器根據(jù)cookie中的sessionid判斷用戶是否登錄,再顯示用戶數(shù)據(jù)。
如果項(xiàng)目采用前后端分離思想,服務(wù)器只提供接口,不進(jìn)行服務(wù)器渲染,那么這種辦法是行不通了。

2、$route.query

我們可以在路由跳轉(zhuǎn)的時(shí)候帶上登錄請(qǐng)求的參數(shù):

router.push({name:'index', query:{username: 'xxx', password: 'xxxxxx'}})
...this.$ajax({  url: 'xxx',  method: 'post',  data: {    username: this.$route.query.username,    password: this.$route.query.password
  }
})

這樣登錄參數(shù)會(huì)被保存在url中,像這樣:“http://xxx.xxx.xxx/index?username=xxx&password=xxxxxx”,然后在created鉤子中調(diào)用登錄

網(wǎng)友評(píng)論