vuex持久化存儲,手動保存到localStorage

vuex持久化存儲,手動保存到localStorage

  • 一、vue2
    • 1. 手動存儲到localStorage
      • store/index.js
    • 2. 使用持久化存儲插件
      • store/index.js
      • store/modules/otherData.js
      • 保存到localStorage
  • 二、vue3
    • 1. index.ts
    • 2. store/modules/globalData.ts
    • 3. 在組件中使用App.vue


一、vue2

1. 手動存儲到localStorage

store/index.js

import Vue from 'vue'
import Vuex from 'vuex'Vue.use(Vuex)// 本地存儲-修改
const storageSet = (key, value) => {localStorage.setItem(key, JSON.stringify(value))
}// 本地存儲-獲取
const storageGet = (key) => {return JSON.parse(localStorage.getItem(key))
}export default new Vuex.Store({// 數據源 使用:this.$store.state.xxxstate: {user: {} // 用戶信息},// 派生數據 使用:this.$store.getters.xxxgetters: {// 獲取當前-用戶對象GET_USER(state) {state.user = storageGet('STORE_USER') || {}return state.user}},// 更改數據-同步 使用:this.$store.commit('xxx', data)mutations: {// 保存當前-用戶對象SET_USER(state, data) {state.user = datastorageSet('STORE_USER', data)}},// mutations裝飾器-異步actions: { }
})

2. 使用持久化存儲插件

store/index.js

提示:vuex持久化存儲

import Vue from 'vue'
import Vuex from 'vuex'// Vuex持久化存儲
import VuexPersistence from 'vuex-persist'
const vuexLocal = new VuexPersistence({storage: window.localStorage
})import otherData from "./modules/otherData.js"Vue.use(Vuex)const state = {}const getters = {}const mutations = {}const actions = {}export default new Vuex.Store({state,getters,mutations,actions,modules: {// 模塊命名,要在 js文件 聲明namespaced: true才有用otherData,},plugins: [vuexLocal.plugin]
})

store/modules/otherData.js

// state
let state = {// 字典數據dictionaryData: [],
}// getters
let getters = {// 字典數據get_dictionaryData(state) {return state.dictionaryData},
}// mutations,以isShow屬性為例
let mutations = {// 字典數據change_dictionaryData(state, data) {state.dictionaryData = data},
}// ctions
let actions = {// 這里有兩種寫法,本質上一樣// 寫法1,無參asChangeShow(context) {context.commit('changeShow')},// 寫法2,無參// asChangeShow({ commit }) {//     commit('changeShow')// }//有參asChangeName({ commit }, data) {commit('changeName', data)}
}
export default {namespaced: true, // 是否開啟模塊state,getters,mutations,actions
}

保存到localStorage

App.vue

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

二、vue3

1. index.ts

// store/index.js  
import { createStore } from 'vuex'; // 從 localStorage 中獲取初始狀態 
const savedState = localStorage.getItem('vuexState');  
const initialState = savedState ? JSON.parse(savedState)  : {}; import globalData from "./modules/globalData"const store = createStore({ state() { return initialState; }, mutations: { }, actions: { }, getters: { },modules: {globalData,}
}); // 監聽狀態變化,將狀態保存到 localStorage 
store.subscribe((mutation,  state) => { localStorage.setItem('vuexState',  JSON.stringify(state));  
}); export default store; 

2. store/modules/globalData.ts

const state:any = {menuList: []
}
const mutations:any = {change_menuList(state: any, data: any){state.menuList = data}menuList: []
}
export default {namespace: "globalData",state,mutations,
}

使用

<script setup> 
import { useStore } from 'vuex'; const store = useStore(); store.state.globalData.menuList // 獲取
store.commit("change_menuList", menu) //更新</script>

3. 在組件中使用App.vue

<template> <div> <p>Count: {{ count }}</p> <button @click="increment">Increment</button> <button @click="decrement">Decrement</button> </div> 
</template> <script setup> 
import { useStore } from 'vuex'; const store = useStore(); const count = store.getters.getCount;  const increment = () => { store.dispatch('increment');  
}; const decrement = () => { store.dispatch('decrement');  
}; 
</script> 

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/73729.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/73729.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/73729.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

nodejs使用 mysql2 模塊獲取 mysql 中的 json字段,而不是 mysql

mysql 模塊獲取的 json 字段&#xff0c;是字符串mysql2 模塊獲取的 json 字段&#xff0c;是符合預期的 json 對象 mysql mysql2 最后編輯于&#xff1a;2025-02-24 22:16:53 © 著作權歸作者所有,轉載或內容合作請聯系作者 喜歡的朋友記得點贊、收藏、關注哦&#xff01;…

鴻蒙(OpenHarmony)開發實現 息屏/亮屏 詳情

官網參考鏈接 實現點擊關閉屏幕&#xff0c;定時5秒后喚醒屏幕 權限 {"name": "ohos.permission.POWER_OPTIMIZATION"}代碼實現 import power from ohos.power;Entry Component struct Page3 {private timeoutID: number | null null; // 初始化 timeout…

【網工第6版】第1章 計算機網絡概論

目錄 1計算機網絡形成和發展 ■計算機網絡 ■我國互聯網發展 ■計算機網路分類 ■計算機網絡應用 2 OSI和TCP/IP參考模型 ■網絡分層的意義 ■OSI參考模型 ■TCP/IP參考模型 ■TCP/IP參考模型協議 3 數據封裝與解封過程 ■封裝 ■解封 1計算機網絡形成和發展 ■計…

理解我們單片機擁有的資源

目錄 為什么要查詢單片機擁有的資源 所以&#xff0c;去哪些地方可以找數據手冊 一個例子&#xff1a;STM32F103C8T6 前言 本文章隸屬于項目&#xff1a; Charliechen114514/BetterATK: This is a repo that helps rewrite STM32 Common Repositorieshttps://github.com/C…

《我的Python覺醒之路》之轉型Python(十五)——控制流

[今天是2025年3月17日&#xff0c;繼續復習第一章節、第二章節的內容 ] 《我的Python覺醒之路》之轉型Python&#xff08;十四&#xff09;——控制流

AndroidStudio+Android8.0下的Launcher3 導入,編譯,燒錄,調試

文章目錄 編譯完成搜索輸出文件Android.mk配置gradle編譯環境報錯一報錯二報錯三輸出文件下載INSTALL_FAILED_TEST_ONLY查找系統簽名查找簽名工具開始簽名查看簽名簽名問題重新生成秘鑰解決方案生成成功挽救錯誤:重新刷機更換testkey秘鑰keystore生成keystoreINSTALL_FAILED_S…

Linux--gdb/cgdb

ok&#xff0c;我們今天學習gdb的安裝和使用 調試器-gdb/cgdb使用 VS、VScode編寫的代碼一般都是release格式的&#xff0c;gdb 的格式一般是debug 換成debug模式命令 :-g gdb會記錄最新的一條命令&#xff0c;直接回車就是默認執行該命令 一個調試周期下&#xff0c;斷點…

Oracle GoldenGate 全面解析

Oracle GoldenGate 全面解析 Oracle GoldenGate 是一種實時數據集成和復制解決方案,廣泛應用于數據同步、數據庫遷移、高可用性和災難恢復等場景。以下將詳細解答您提出的關于 Oracle GoldenGate 的一系列問題。 1. Oracle GoldenGate 的架構組成及其核心組件的作用 架構組成…

ModBus TCP/RTU互轉(主)(從)|| Modbus主動輪詢下發的工業應用 || 基于智能網關的串口服務器進行Modbus數據收發的工業應用

目錄 前言 一、ModBus TCP/RTU互轉&#xff08;從&#xff09;及應用|| 1.1 舉栗子 二、ModBus TCP/RTU互轉&#xff08;主&#xff09; 2.1 舉栗子 三、ModBus 主動輪詢 3.1 Modbus主動輪詢原理 3.2 Modbus格式上傳與下發 3.2.1.設置Modbus主動輪詢指令 3.2.2 設…

場景題:一個存儲IP地址的100G 的文件, 找出現次數最多的 IP ?

和大文件中存id&#xff0c;然后要求排序問題一樣的處理思路 使用MapReduce的思想解決&#xff0c;加上哈希分割&#xff0c;先將大文件中的IP地址按照哈希函數進行分割&#xff0c;存到多個文件上&#xff0c;接著每個分片單獨處理&#xff0c;用Hashmap統計IP出現頻次&#…

【操作系統安全】任務2:用戶與用戶組

目錄 一、用戶與用戶組介紹 1.1 用戶 1.2 用戶組 1.3 用戶與用戶組的關系 二、用戶與用戶組管理 2.1 用戶管理 2.1.1 創建用戶 2.1.2 設置用戶密碼 2.1.3 刪除用戶 2.2 用戶組管理 2.2.1 創建用戶組 2.2.2 刪除用戶組 2.2.3 將用戶添加到用戶組 三、影子賬戶創建…

OpenCV計算攝影學(20)非真實感渲染之增強圖像的細節函數detailEnhance()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 此濾波器增強特定圖像的細節。 cv::detailEnhance用于增強圖像的細節&#xff0c;通過結合空間域和頻率域的處理&#xff0c;提升圖像中特定細節…

Git 使用指南

Git 是一種分布式版本控制系統&#xff0c;可以追蹤文件的變化并協助多人協作開發項目。下面是 Git 的基本概念和使用方式&#xff1a; 倉庫&#xff08;Repository&#xff09;&#xff1a;Git 用來存儲項目的地方&#xff0c;可以理解為項目的文件夾&#xff0c;包含項目的所…

java 中散列表(Hash Table)和散列集(Hash Set)是基于哈希算法實現的兩種不同的數據結構

在 Java 中&#xff0c;散列表&#xff08;Hash Table&#xff09;和散列集&#xff08;Hash Set&#xff09;是兩種不同的數據結構&#xff0c;但它們都基于哈希表的原理來實現。下面是它們的聯系與區別、實現類以及各自的優缺點&#xff0c;并用表格進行對比整理。 聯系與區…

vue2自定義指令實現 el-input 輸入數字,小數點兩位 最高10位,不滿足則截取符合規則的值作為新值

步驟 1&#xff1a;創建自定義指令 // 處理輸入值&#xff0c;確保符合規則 function processValue(value) {// 過濾非數字和小數點let filtered value.replace(/[^\d.]/g, );const firstDotIndex filtered.indexOf(.);// 處理多個小數點&#xff0c;保留第一個if (firstDot…

10、基于osg引擎生成熱力圖高度圖實現3D熱力圖可視化、3D熱力圖實時更新(帶過渡效果)

1、結果 2、完整C代碼 #include <sstream> #include <iomanip> #include <iostream> #include <vector> #include <random> #include <cmath> #include <functional> #include <osgViewer/viewer> #include <osgDB/Read…

海量數據查詢加速:Presto、Trino、Apache Arrow

1. 引言 在大數據分析場景下,查詢速度往往是影響業務決策效率的關鍵因素。隨著數據量的增長,傳統的行存儲數據庫難以滿足低延遲的查詢需求,因此,基于列式存儲、向量化計算等技術的查詢引擎應運而生。本篇文章將深入探討 Presto、Trino、Apache Arrow 三種主流的查詢優化工…

Pycharm 社區版安裝教程

找到安裝包雙擊安裝文件---點擊下一步 一般路徑是&#xff1a;C:\Rambo\Software\Development 選擇完成后就是如下地址&#xff1a; C:\Rambo\Software\Development\PyCharm Community Edition 2024.3.3 點擊上述3個位置就可以了----下一步 等待安裝就可以了---完成后點擊完成…

vue3 elementUi table自由渲染組件

文章目錄 前言CustomTable如何使用tableColumn 屬性h函數創建原生元素創建組件動態生成 前言 elementui中的table組件&#xff0c;表格中想要自由地渲染內容&#xff0c;是一種比較麻煩的事情&#xff0c;比如你表格中想要某一列插入一個button按鈕&#xff0c;是不是要用插槽…

Mermaid 子圖 + 拖拽縮放:讓流程圖支持無限細節展示

在技術文檔、項目管理和可視化分析中&#xff0c;流程圖是傳遞復雜邏輯的核心工具。傳統流程圖往往靜態且難以適應細節展示&#xff0c;而 Mermaid 與 svg-pan-zoom 的結合&#xff0c;則為這一痛點提供了完美解決方案。本文將深入解析如何通過 Mermaid 的子圖&#xff08;subg…