亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue單頁應(yīng)用在頁面刷新時保留狀態(tài)數(shù)據(jù)的方法

 更新時間:2018年09月21日 11:41:57   作者:aliven1  
今天小編就為大家分享一篇vue單頁應(yīng)用在頁面刷新時保留狀態(tài)數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在Vue單頁應(yīng)用中,如果在某一個具體路由的具體頁面下點(diǎn)擊刷新,那么刷新后,頁面的狀態(tài)信息可能就會丟失掉。這時候應(yīng)該怎么處理呢?如果你也有這個疑惑,這篇文章或許能夠幫助到你

一、問題

現(xiàn)在產(chǎn)品上有個需求:單頁應(yīng)用走到某個具體的頁面,然后點(diǎn)擊刷新后,刷新的頁面要與刷新前的頁面要保持一致。

這時候就需要我們保存刷新之前頁面的狀態(tài)。

二、一種解決方案

在這個Vue單頁應(yīng)用中,王二是用Vuex作為狀態(tài)管理的,一開始王二的思路是將Vuex里的數(shù)據(jù)同步更新到localStorage里。

即:一改變vuex里的數(shù)據(jù),便觸發(fā)localStorage.setItem 方法,參考如下代碼:

import Vue from "vue"
import Vuex from "vuex"
 
Vue.use(Vuex)
 
function storeLocalStore (state) {
  window.localStorage.setItem("userMsg",JSON.stringify(state));
}
 
export default new Vuex.Store({
  state: {
    username: "王二",
    schedulename: "標(biāo)題",
    scheduleid: 0,
  },
  mutations: {
    storeUsername (state,name) {
      state.username = name
      storeLocalStore (state)
    },
    storeSchedulename (state,name) {
      state.schedulename = name
      storeLocalStore (state)
    },
    storeScheduleid (state,id) {
      state.scheduleid = Number(id)
      storeLocalStore (state)
    },
  }
})

然后在頁面加載時再從localStorage里將數(shù)據(jù)取回來放到vuex里,于是王二在 App.vue 的 created 鉤子函數(shù)里寫下了如下代碼:

localStorage.getItem("userMsg") && this.$store.replaceState(JSON.parse(localStorage.getItem("userMsg")));
 
//考慮到第一次加載項(xiàng)目時localStorage里沒有userMsg的信息,所以在前面要先做判斷

這樣就能比較圓滿的解決問題了。

三、另一種解決方案

以上的解決方法由于要頻繁地觸發(fā) localStorage.setItem 方法,所以對性能很不友好。而且如果一直同步vuex里的數(shù)據(jù)到localStorage里,我們直接用localStorage做狀態(tài)管理好了,似乎也沒有必要再用vuex。

這時候王二想,如果有什么方法能夠監(jiān)聽到頁面的刷新事件,然后在那個監(jiān)聽方法里將Vuex里的數(shù)據(jù)儲存到localStorage里,那該多好。

很幸運(yùn),還真有這樣的監(jiān)聽事件,我們可以用 beforeunload 來達(dá)到以上目的,于是王二在 App.vue 的 created 鉤子函數(shù)里寫下了如下代碼:

  //在頁面加載時讀取localStorage里的狀態(tài)信息
  localStorage.getItem("userMsg") && this.$store.replaceState(JSON.parse(localStorage.getItem("userMsg")));
  
  //在頁面刷新時將vuex里的信息保存到localStorage里
  window.addEventListener("beforeunload",()=>{
    localStorage.setItem("userMsg",JSON.stringify(this.$store.state))
  })

這樣的話,似乎就比較完美了。

2018年03月27日補(bǔ)充:

王二在使用上述方法時,遇到了一個問題,就是:在開發(fā)階段,如果在Vuex里添加新的字段,則新的字段不能被保存到localStorage里,于是上述代碼修改如下:

  //在頁面加載時讀取localStorage里的狀態(tài)信息
  localStorage.getItem("userMsg") && this.$store.replaceState(Object.assign(this.$store.state,JSON.parse(localStorage.getItem("userMsg"))));
  
  //在頁面刷新時將vuex里的信息保存到localStorage里
  window.addEventListener("beforeunload",()=>{
    localStorage.setItem("userMsg",JSON.stringify(this.$store.state))
  })

以上這篇vue單頁應(yīng)用在頁面刷新時保留狀態(tài)數(shù)據(jù)的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • VUE事件處理之@click用法示例代碼

    VUE事件處理之@click用法示例代碼

    在Vue進(jìn)行前端開發(fā)中事件處理是必不可少的功能,下面這篇文章主要給大家介紹了關(guān)于VUE事件處理之@click用法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • webstorm和.vue中es6語法報錯的解決方法

    webstorm和.vue中es6語法報錯的解決方法

    本篇文章主要介紹了webstorm和.vue中es6語法報錯的解決方法,小編總結(jié)了webstorm和.vue中出現(xiàn)的es6語法報錯,避免大家采坑,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Vue Echarts簡易實(shí)現(xiàn)儀表盤

    Vue Echarts簡易實(shí)現(xiàn)儀表盤

    這篇文章主要為大家詳細(xì)介紹了Vue Echarts實(shí)現(xiàn)儀表盤案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-12-12
  • Vue引入騰訊地圖全過程(搜索獲取定位)

    Vue引入騰訊地圖全過程(搜索獲取定位)

    最近需要在項(xiàng)目中使用地圖顯示點(diǎn)位信息,所以引入了騰訊地圖,這篇文章主要給大家介紹了關(guān)于Vue引入騰訊地圖(搜索獲取定位)的相關(guān)資料,需要的朋友可以參考下
    2023-10-10
  • Vue使用富文本編輯器Vue-Quill-Editor(含圖片自定義上傳服務(wù)、清除復(fù)制粘貼樣式等)

    Vue使用富文本編輯器Vue-Quill-Editor(含圖片自定義上傳服務(wù)、清除復(fù)制粘貼樣式等)

    這篇文章主要介紹了Vue項(xiàng)目中使用富文本編輯器Vue-Quill-Editor(含圖片自定義上傳服務(wù)、清除復(fù)制粘貼樣式等)的相關(guān)知識,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • vue3沒有this的解決方案

    vue3沒有this的解決方案

    這篇文章主要介紹了vue3沒有this的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue打包后修改配置后端IP地址、端口等信息兩種方法

    vue打包后修改配置后端IP地址、端口等信息兩種方法

    這篇文章主要給大家介紹了關(guān)于vue打包后修改配置后端IP地址、端口等信息的兩種方法,文中通過代碼示例以及圖文介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue打包具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • Vue中forEach()的使用方法例子

    Vue中forEach()的使用方法例子

    這篇文章主要給大家介紹了關(guān)于Vue中forEach()使用方法的相關(guān)資料,forEach和map是數(shù)組的兩個方法,作用都是遍歷數(shù)組,在vue項(xiàng)目的處理數(shù)據(jù)中經(jīng)常會用到,需要的朋友可以參考下
    2023-09-09
  • 詳解vue 兼容IE報錯解決方案

    詳解vue 兼容IE報錯解決方案

    這篇文章主要介紹了詳解vue 兼容IE報錯解決方案,詳細(xì)的介紹了幾種原因及其解決方案,非常具有實(shí)用價值,需要的朋友可以參考下
    2018-12-12
  • vuex中的state、getters、mutations、actions之間的關(guān)系解讀

    vuex中的state、getters、mutations、actions之間的關(guān)系解讀

    這篇文章主要介紹了vuex中的state、getters、mutations、actions之間的關(guān)系,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評論