小編給大家分享一下在Vue中如何實現添加全局store,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
npm install --save vuex
store和在new Vue中聲明store
import store from './store' store,
在page文件下創建一個module的js文件(內容如下)
const state = { HomeStatus:{ LoginStatus:false }, Users:[], } const mutations = { ['setuseinfo'] (state, data) { }, } const actions = { }
在store文件下創建一個index的js文件
import Vue from 'vue' import Vuex from 'vuex' import page from '../page/module' Vue.use(Vuex) export default new Vuex.Store({ state: {}, modules:{ page } })
state
:存儲狀態。也就是變量;
getters
:派生狀態。也就是set、get中的get,有兩個可選參數:state、getters分別可以獲取state中的變量和其他的getters。外部調用方式:store.getters.personInfo()。就和vue的computed差不多;
mutations
:提交狀態修改。也就是set、get中的set,這是vuex中唯一修改state的方式,但不支持異步操作。第一個參數默認是state。外部調用方式:store.commit(‘SET_AGE’, 18)。和vue中的methods類似。
actions
:和mutations類似。不過actions支持異步操作。第一個參數默認是和store具有相同參數屬性的對象。外部調用方式:store.dispatch(‘nameAsyn’)。this.$store.dispatch(‘user/login’, this.loginForm)
modules
:store的子模塊,內容就相當于是store的一個實例。調用方式和前面介紹的相似,只是要加上當前子模塊名,如:store.a.getters.xxx()。
import Vue from 'vue' import Vuex from 'vuex' import state from './state.js' import getters from './getters' import mutations from './mutations.js' import actions from './actions.js' //安裝Vue Devtools調試工具https://blog.csdn.net/li22356/article/details/113092495 //掛載Vuex,幫助手冊https://www.jianshu.com/p/2e5973fe1223 //模塊化可參考http://www.dadijd.cn/article/150752.htm Vue.use(Vuex); //創建VueX對象,單頁面使用<h2>{{ $store.state.name }}</h2>console.log(this.$store.state.name) //新增state對象Vue.set(state,"age",15),刪除Vue.delete(state,'age') const store = new Vuex.Store({ //存放數據,存放狀態 //使用方法 state, //加工state成員給外界 //state 當前VueX對象中的狀態對象 // getters 當前getters對象,用于將getters下的其他getter拿來用 //組件使用this.$store.getters.fullInfo getters, //state成員操作,操作state數據的方法的集合,比如對該數據的修改、增加、刪除等等。 //組件調用this.$store.commit('SET_TOKEN','new token')掛載方法 //同步處理 mutations, //異步處理 //組件中使用this.$store.dispatch('aEdit','new TOKEN') actions }); export default () => { return store }
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ //這里放全局參數,比如用戶登錄信息 state: { token: "helloVueX", name: "", age: "" }, mutations: { //這里是set方法,比如對該數據的修改、增加、刪除等等。 //組件調用this.$store.commit('SET_TOKEN','new token')掛載方法 SET_TOKEN: (state, token) => { state.token = token console.log(state.token); } }, //getters 當前getters對象(可對對象進行二次更改),用于將getters下的其他getter拿來用,組件通過this.$store.getters.fullInfo拿來使用 getters: { token: state => state.token, nameInfo(state) { return "姓名:" + state.name }, fullInfo(state, getters) { return getters.nameInfo + '年齡:' + state.age } }, //異步處理 //組件中使用this.$store.dispatch('aEdit','new TOKEN') actions: { QQlogin({commit}, token) { return new Promise((resolve, reject) => { setToken(token); //把token存放到cookie里 commit('SET_TOKEN', token) //commit調用mutations 數據 resolve() }) }, aEdit(context, payload) { return new Promise((resolve, reject) => { setTimeout(() => { context.commit('SET_TOKEN', payload) resolve() }, 2000) }) } }, modules: { //這里是我自己理解的是為了給全局變量分組,所以需要寫提前聲明其他store文件,然后引入這里 } })
我們用vuex時通常會分功能創建多的module,單個module里的操作大家應該很清楚,那多個module之間怎么調用了?
詳細代碼:
現在我有兩個module:user 和 menu,要在user中調用menu的actions方法,操作如下:
const user = { state: { permissions: [] }, mutations: { SET_PERMISSIONS: (state, permissions) => { state.permissions = permissions } }, actions: { getPermissions({commit}) { queryPermissions().then(res => { sessionStorage.setItem('permissions', JSON.stringify(res)) this.dispatch('setPermissions', res); // 調本module里的方法 }) }, setPermissions({commit, dispatch, state, rootState}, data) { commit('SET_PERMISSIONS', data); // 本module的commit dispatch('setMenuData', data); // 調menu里的方法 console.log(rootState.menu.menus); // 取menu里的參數 } } } export default user const menu = { state: { menus: [] }, mutations: { SET_MENUS: (state, data) => { state.menus = data } }, actions: { setMenuData({commit, state}, data) { commit('SET_MENUS', data); } } } export default menu
解釋:
actions里各個方法的第一個參數其實有很多屬性,只是我們平時習慣了解構的寫法,如setMenuData({commit, state},data)。當把第一個參數的值全輸出,如setMenuData(param,data),輸出param會發現其中包含以下屬性:
const actions = { // 根據權限動態生成路由 async generateRoutes({ commit }) { // 執行代碼 } }
created() { this.generateRoutes() }, methods: { ...mapActions('menu', [ 'generateRoutes' ]) }
看完了這篇文章,相信你對“在Vue中如何實現添加全局store”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。