本篇内容介绍了“vuex中特殊应用实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
需求: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 id="app">
<a-spin size="large" :spinning="this.$store.state.spinTag">
<router-view></router-view>
</a-spin>
</div>
</template>
“vuex中特殊应用实例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注天达云网站,小编将为大家输出更多高质量的实用文章!