中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Vue中$route序列號報錯怎么解決

發布時間:2023-04-17 16:46:42 來源:億速云 閱讀:107 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Vue中$route序列號報錯怎么解決”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Vue中$route序列號報錯怎么解決”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

由于Vuex在瀏覽器刷新是會丟失數據,所以我在項目里使用了Vuex持久化存儲的功能,我這邊實現的方案是監聽頁面刷新的事件,將Vuex中的數據存到sessionStorage中,在頁面初始化的時候再將sessionStorage中的數據設進Vuex中,具體代碼如下

create(){
      //在頁面加載時讀取sessionStorage里的狀態信息
    if (sessionStorage.getItem("store")) {
      this.$store.replaceState(
        Object.assign(
          {},
          this.$store.state,
          JSON.parse(sessionStorage.getItem("store"))
        )
      );
       sessionStorage.removeItem("store");
    }

    //在頁面刷新時將vuex里的信息保存到sessionStorage里
    window.addEventListener("beforeunload", () => {
      sessionStorage.setItem("store", JSON.stringify(this.$store.state));
    });
}

這樣一個簡單的Vuex持久化儲存的功能就實現了,瀏覽器刷新后我們也能讀取到Vuex中儲存的數據,但是突然有一天,這個功能失效了,頁面也沒有報錯,經過我的一番摸索,最終將問題鎖定在了Vuex中儲存的$route對象上

$Route路由對象屬性

$Route對象上有以下這幾個屬性

  • path:字符串,對應當前路由的路徑,總是解析為絕對路徑,如 "/foo/bar"

  • params:一個 key/value 對象,包含了動態片段和全匹配片段,如果沒有路由參數,就是一個空對象

  • query:一個 key/value 對象,表示 URL 查詢參數。例如,對于路徑 /foo?user=1,則有 $route.query.user == 1,如果沒有查詢參數,則是個空對象

  • hash:當前路由的 hash 值 (帶 #) ,如果沒有 hash 值,則為空字符串

  • fullPath:完成解析后的 URL,包含查詢參數和 hash 的完整路徑

  • matched:一個數組,包含當前路由的所有嵌套路徑片段的路由記錄 。路由記錄就是 routes 配置數組中的對象副本 (還有在 children 數組)

問題就出在了$route這個路由對象上,我們在頁面刷新時要將Vuex中的數據轉換成字符串,再進行儲存

    //在頁面刷新時將vuex里的信息保存到sessionStorage里
    window.addEventListener("beforeunload", () => {
      sessionStorage.setItem("store", JSON.stringify(this.$store.state));
    });

而store中如果有$route就會報錯,這是因為$route包含了一些非序列話的屬性,例如函數、循環引用等;
當使用JSON.stringify($route)時,可能會報錯TypeError: Converting circular structure to JSON,這是因為$route對象包含循環引用,即對象內部存在相互引用,導致JSON.stringify()無法序列化這個對象,從而拋出這個錯誤。

解決方法

為了解決這個問題,你可以將$route對象轉換成一個新的純JavaScript對象,然后再進行序列化。可以使用Object.assign()方法來實現這一點,如下所示:

JSON.stringify(Object.assign({}, $route))

這個方法會創建一個新的JavaScript對象,將$route的屬性復制到這個新對象中,并返回這個新對象。由于這個新對象只包含純JavaScript數據,因此可以安全地序列化它。

讀到這里,這篇“Vue中$route序列號報錯怎么解決”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

轮台县| 吕梁市| 聊城市| 乌兰县| 苏尼特右旗| 梓潼县| 尉氏县| 德惠市| 张家川| 富平县| 虞城县| 青浦区| 安宁市| 安远县| 霸州市| 扶风县| 黔西| 建阳市| 营山县| 衡水市| 巴林右旗| 石阡县| 棋牌| 东辽县| 阜新市| 兴国县| 沛县| 山东省| 扬州市| 龙井市| 大丰市| 上饶县| 文安县| 凭祥市| 临安市| 青铜峡市| 泸州市| 怀远县| 林芝县| 九江县| 横山县|