Vue 关于Store的用法小结

 更新时间:2024年08月29日 11:17:50   作者:Teln_小凯  
Vue Store是的状态管理模式和库,它提供了一种集中存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化,这篇文章主要介绍了Vue 关于Store的用法,需要的朋友可以参考下

Store就是全局变量都是可以双向绑定的,以下是模块的用法:

state定义的是变量名称,mutations里面是给变量赋值的方法

export default {
    namespaced: true,
    state: {
        //打开的Tabs
        tabs: null,
        //当前显示的key
        selectTabKey: null
    },
    mutations: {
        setSelectTabKey(state, key) {
            state.selectTabKey = key;
            localStorage.setItem(process.env.ADMIN_TABS_SELECT_KEY, JSON.stringify(key));
        },
        setTabs(state, tabs) {
            state.tabs = tabs;
            localStorage.setItem(process.env.ADMIN_TABS_KEY, JSON.stringify(tabs));
        },
        initTabs(state, tab) {
            var localTabs = localStorage.getItem(process.env.ADMIN_TABS_KEY)
            if (localTabs != null) {
                state.tabs = JSON.parse(localTabs);
                state.selectTabKey = JSON.parse(localStorage.getItem(process.env.ADMIN_TABS_SELECT_KEY));
            } else {
                state.selectTabKey = tab.key;
                localStorage.setItem(process.env.ADMIN_TABS_SELECT_KEY, JSON.stringify(state.selectTabKey));
                state.tabs = [];
                state.tabs.push({
                    title: tab.title,
                    icon: tab.icon,
                    content: "",
                    key: tab.key,
                    closable: false,
                    icon_bk: "",
                    url: tab.url,
                });
                localStorage.setItem(process.env.ADMIN_TABS_KEY, JSON.stringify(state.tabs));
            }
        },
        addTabs(state, tab) {
            state.selectTabKey = tab.key;
            localStorage.setItem(process.env.ADMIN_TABS_SELECT_KEY, JSON.stringify(state.selectTabKey));
            var localTabs = localStorage.getItem(process.env.ADMIN_TABS_KEY)
            if (localTabs != null) {
                state.tabs = JSON.parse(localTabs);
            }
            if (state.tabs == null) {
                state.tabs = [];
            }
            //判断有没有在tabs里面
            var isAdd = false;
            for (var pn of state.tabs) {
                if (pn.key == tab.key) {
                    isAdd = true;
                    break;
                }
            }
            if (isAdd == false) {
                state.tabs.push({
                    title: tab.title,
                    icon: tab.icon,
                    content: "",
                    key: tab.key,
                    closable: true,
                    icon_bk: "",
                    url: tab.url,
                });
            }
            localStorage.setItem(process.env.ADMIN_TABS_KEY, JSON.stringify(state.tabs));
        },
    }
}

然后整合模块

import menu from './menu'
import tab from './tab'
import setting from './setting'
export default {menu, tab,setting}

 对外输出

import Vue from 'vue'
import 'es6-promise/auto'
import Vuex from 'vuex'
import modules from './modules'
Vue.use(Vuex)
const store = new Vuex.Store({modules})
export default store

 Main方法注册

 获取

this.$store.state.tab.selectTabKey

赋值

this.$store.commit("tab/setSelectTabKey", targetKey);

 监控值改变

watch: {
    "$store.state.tab.selectTabKey": {
      handler: function (newVal, oldVal) {
        if (this.currTarger != newVal) {
          this.onTabChange(newVal);
        }
      },
    },
  },

可以直接绑定

注意点,全局变量存localstore的时候必须转JSONString,取的时候也得转,否则 绑定到控件上会失效

localStorage.setItem(process.env.ADMIN_TABS_SELECT_KEY, JSON.stringify(key));

 取

state.selectTabKey = JSON.parse(localStorage.getItem(process.env.ADMIN_TABS_SELECT_KEY));

之前直接这样写会导致无法绑定到控件

localStorage.setItem(process.env.ADMIN_TABS_SELECT_KEY, key);

state.selectTabKey = localStorage.getItem(process.env.ADMIN_TABS_SELECT_KEY);

到此这篇关于Vue 关于Store的用法的文章就介绍到这了,更多相关Vue Store 用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue2.x双向数据绑定原理解析

    vue2.x双向数据绑定原理解析

    双向数据绑定原理主要运用了发布订阅模式来实现的,通过Object.defineProperty对数据劫持,触发getter,setter方法,这篇文章主要介绍了vue2.x双向数据绑定原理,需要的朋友可以参考下
    2023-02-02
  • vue项目中$t()的意思是什么

    vue项目中$t()的意思是什么

    这篇文章主要介绍了vue项目中$t()的意思是什么,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue中fragment.js使用方法详解

    Vue中fragment.js使用方法详解

    这篇文章主要为大家详细介绍了Vue中fragment.js的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Vue Element前端应用开发之Vuex中的API Store View的使用

    Vue Element前端应用开发之Vuex中的API Store View的使用

    这篇文章主要介绍了Vue Element前端应用开发之Vuex中的API Store View的使用,对Vue感兴趣的同学,可以参考下
    2021-05-05
  • 浅谈vue权限管理实现及流程

    浅谈vue权限管理实现及流程

    这篇文章主要介绍了浅谈vue权限管理实现及流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • 深入理解使用Vue实现Context-Menu的思考与总结

    深入理解使用Vue实现Context-Menu的思考与总结

    这篇文章主要介绍了使用Vue实现Context-Menu的思考与总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-03-03
  • 解决Antd 里面的select 选择框联动触发的问题

    解决Antd 里面的select 选择框联动触发的问题

    这篇文章主要介绍了解决Antd 里面的select 选择框联动触发的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • vue+axios+java实现文件上传功能

    vue+axios+java实现文件上传功能

    这篇文章主要为大家详细介绍了vue+axios+java实现文件上传功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • vue解决使用$http获取数据时报错的问题

    vue解决使用$http获取数据时报错的问题

    今天小编就为大家分享一篇vue解决使用$http获取数据时报错的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • Vue3实现批量异步更新

    Vue3实现批量异步更新

    这篇文章主要为大家详细介绍了Vue3批量异步更新是如何实现的,文中的示例代码简洁易懂,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-08-08

最新评论