91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決vue-router路由參數刷新消失的問題

發布時間:2021-07-16 11:14:14 來源:億速云 閱讀:280 作者:小新 欄目:web開發

這篇文章主要為大家展示了“如何解決vue-router路由參數刷新消失的問題”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何解決vue-router路由參數刷新消失的問題”這篇文章吧。

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

解決方案:

1、session&服務器渲染

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

2、$route.query

我們可以在路由跳轉的時候帶上登錄請求的參數:

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
 }
})

這樣登錄參數會被保存在url中,像這樣:“http://xxx.xxx.xxx/index?username=xxx&password=xxxxxx”,然后在created鉤子中調用登錄接口來返回數據。

即使密碼進行了md5加密,將用戶名密碼這類敏感信息放在url中肯定也是不合理。

3、cookie

另一個辦法是把登錄參數存入cookie,然后在created鉤子中獲取cookie中存的信息,再調用登錄接口。將用戶名密碼存入cookie中同樣不合理,改進版是登錄成功后服務器返回一個token,在有效期內通過token獲取用戶數據。

cookie存取數據比較麻煩,因為cookie中鍵值對是字符串并以 "=" 鏈接,需要額外寫操作cookie的方法。

<script>
 function setCookie (name, value, exdays) {
  let date = new Date()
  date.setTime(date.getTime() + (exdays * 24 * 60 * 60 * 1000))
  let expires = "expires=" + date.toGMTString()
  document.cookie = name + "=" + value + "; " + expires
 }
 function getCookie (name) {
  name = name + "="
  let cookieArr = document.cookie.split(';')
  for (let i = 0; i < cookieArr.length; i++) {
   let cookie = cookieArr[i].trim()
   if (cookie.indexOf(name) === 0) {
    return cookie.slice(name.length)
   }
  }
  return ""
 }

4、HTML5 Web存儲

提到Web存儲,潛意識肯定覺得很多瀏覽器都不支持,其實IE8及以上都支持localStorage和sessionStorage了。Vue項目最低支持IE9,所以可以放心的使用Web存儲。

localStorage存儲數據沒有時間限制,不主動刪除就不會失效。而sessionStorage是在頁面或者瀏覽器關閉時就會失效,適合本場景應用。

我們可以把token信息存在sessionStorage中,然后每次刷新頁面通過token請求數據;但是既然能夠把token存儲到本地,為什么不直接把常用的數據直接保存到本地呢?利用本地數據,可以減少客戶端網絡請求,還可以降低服務器負擔。

由于localStorage和sessionStorage是只讀的,不能直接將其指向一個對象。也不能利用Object.assign()復制對象,因為值會變成字符串"[object Object]",所有只有通過循環為 sessionStorage 添加屬性了。

...
for (var key in res.data.customer) {
 sessionStorage[key] = res.data.customer[key]
} 
...

以上是“如何解決vue-router路由參數刷新消失的問題”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安阳市| 曲周县| 青川县| 壶关县| 定兴县| 镇原县| 祁东县| 林甸县| 武定县| 岳阳市| 会同县| 衢州市| 博白县| 晋中市| 修水县| 昌都县| 股票| 醴陵市| 台江县| 昌江| 天峻县| 本溪| 曲阳县| 娄烦县| 章丘市| 固始县| 枣庄市| 兰溪市| 阜新市| 冀州市| 武功县| 申扎县| 富阳市| 钟祥市| 延吉市| 呈贡县| 马山县| 新闻| 云梦县| 玉龙| 淮南市|