有需求才会有应用!
需求:vue项目中,我需要一个类似全局的变量保存一个tag的值,在不同层级下的子组件中,对这个变量进行修改,并且使变化的结果作用在组件页面上。
这里使用vuex解决问题,代码如下:
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex); const state = { spinTag: false, //spin组件标记 }; //改变状态的方法 const mutations = { spinTagTAG(state, tag) { state.spinTag = tag; } }; var store = new Vuex.Store({ state, mutations }); export default store;
此时,在任意子组件中用一下代码即可完成我需求中提到得,修改值并且作用与组件页面中。
this.$store.commit('spinTagTAG', true); // 打开spin组件
此需求来源于antd vue下spin组件不能覆盖整个浏览器,并且随叫随到,于是,我用了vuex。
代码如下:
<template> <div> <a-spin size="large" :spinning="this.$store.state.spinTag"> <router-view></router-view> </a-spin> </div> </template>
到此这篇关于vuex的特殊应用案例分享的文章就介绍到这了,更多相关vuex的应用案例内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章: