【全栈开发实战小草看书之Web端(四)Vuex状态管理】

全栈开发实战小草看书之Web端(四)Vuex状态管理

代码文件(store/index.js)

import { createStore } from "vuex";
import createPersistedState from "vuex-persistedstate";

const store = createStore({
  state: {
    collapse: false,
    pages: [
      {
        path: "/",
        title: "首页",
      },
    ],
    resources: [],
    user: {},
  },
  mutations: {
    // Collapse
    toggleCollapse: (state) => {
      state.collapse = !state.collapse;
    },
    // Page
    clearPages: (state) => {
      state.pages = [
        {
          path: "/",
          title: "首页",
        },
      ];
    },
    removePage: (state, path) => {
      const index = state.pages.findIndex((i) => {
        return i.path == path;
      });
      state.pages.splice(index, 1);
    },
    savePage: (state, page) => {
      const exist = state.pages.some((i) => {
        return i.path == page.path;
      });
      if (!exist) {
        state.pages.push(page);
      }
    },
    // Resource
    clearResources: (state) => {
      state.resources = [];
    },
    saveResources: (state, resources) => {
      state.resources = resources;
    },
    // User
    clearUser: (state) => {
      state.user = {};
    },
    saveUser: (state, user) => {
      state.user = user;
    },
  },
  plugins: [
    createPersistedState({
      storage: window.sessionStorage,
    }),
  ],
});

export default store;

上一章 【全栈开发实战小草看书之Web端(三)配置文件】
下一章 【全栈开发实战小草看书之Web端(五)Axios封装】

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值