当前位置: 代码网 > it编程>编程语言>Javascript > Vue 关于Store的用法小结

Vue 关于Store的用法小结

2024年09月08日 Javascript 我要评论
store就是全局变量都是可以双向绑定的,以下是模块的用法:state定义的是变量名称,mutations里面是给变量赋值的方法export default { namespaced: true

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 用法内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com