优化字典数据使用store存取
This commit is contained in:
		| @@ -1,7 +1,23 @@ | |||||||
| import Vue from 'vue' | import Vue from 'vue' | ||||||
|  | import store from '@/store' | ||||||
| import DataDict from '@/utils/dict' | import DataDict from '@/utils/dict' | ||||||
| import { getDicts as getDicts } from '@/api/system/dict/data' | import { getDicts as getDicts } from '@/api/system/dict/data' | ||||||
|  |  | ||||||
|  | function searchDictByKey(dict, key) { | ||||||
|  |   if (key == null && key == "") { | ||||||
|  |     return null | ||||||
|  |   } | ||||||
|  |   try { | ||||||
|  |     for (let i = 0; i < dict.length; i++) { | ||||||
|  |       if (dict[i].key == key) { | ||||||
|  |         return dict[i].value | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } catch (e) { | ||||||
|  |     return null | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| function install() { | function install() { | ||||||
|   Vue.use(DataDict, { |   Vue.use(DataDict, { | ||||||
|     metas: { |     metas: { | ||||||
| @@ -9,7 +25,19 @@ function install() { | |||||||
|         labelField: 'dictLabel', |         labelField: 'dictLabel', | ||||||
|         valueField: 'dictValue', |         valueField: 'dictValue', | ||||||
|         request(dictMeta) { |         request(dictMeta) { | ||||||
|           return getDicts(dictMeta.type).then(res => res.data) |           const storeDict = searchDictByKey(store.getters.dict, dictMeta.type) | ||||||
|  |           if (storeDict) { | ||||||
|  |             return new Promise(resolve => { resolve(storeDict) }) | ||||||
|  |           } else { | ||||||
|  |             return new Promise((resolve, reject) => { | ||||||
|  |               getDicts(dictMeta.type).then(res => { | ||||||
|  |                 store.dispatch('dict/setDict', { key: dictMeta.type, value: res.data }) | ||||||
|  |                 resolve(res.data) | ||||||
|  |               }).catch(error => { | ||||||
|  |                 reject(error) | ||||||
|  |               }) | ||||||
|  |             }) | ||||||
|  |           } | ||||||
|         }, |         }, | ||||||
|       }, |       }, | ||||||
|     }, |     }, | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ const getters = { | |||||||
|   sidebar: state => state.app.sidebar, |   sidebar: state => state.app.sidebar, | ||||||
|   size: state => state.app.size, |   size: state => state.app.size, | ||||||
|   device: state => state.app.device, |   device: state => state.app.device, | ||||||
|  |   dict: state => state.dict.dict, | ||||||
|   visitedViews: state => state.tagsView.visitedViews, |   visitedViews: state => state.tagsView.visitedViews, | ||||||
|   cachedViews: state => state.tagsView.cachedViews, |   cachedViews: state => state.tagsView.cachedViews, | ||||||
|   token: state => state.user.token, |   token: state => state.user.token, | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| import Vue from 'vue' | import Vue from 'vue' | ||||||
| import Vuex from 'vuex' | import Vuex from 'vuex' | ||||||
| import app from './modules/app' | import app from './modules/app' | ||||||
|  | import dict from './modules/dict' | ||||||
| import user from './modules/user' | import user from './modules/user' | ||||||
| import tagsView from './modules/tagsView' | import tagsView from './modules/tagsView' | ||||||
| import permission from './modules/permission' | import permission from './modules/permission' | ||||||
| @@ -12,6 +13,7 @@ Vue.use(Vuex) | |||||||
| const store = new Vuex.Store({ | const store = new Vuex.Store({ | ||||||
|   modules: { |   modules: { | ||||||
|     app, |     app, | ||||||
|  |     dict, | ||||||
|     user, |     user, | ||||||
|     tagsView, |     tagsView, | ||||||
|     permission, |     permission, | ||||||
|   | |||||||
							
								
								
									
										50
									
								
								ruoyi-ui/src/store/modules/dict.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								ruoyi-ui/src/store/modules/dict.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | |||||||
|  | const state = { | ||||||
|  |   dict: new Array() | ||||||
|  | } | ||||||
|  | const mutations = { | ||||||
|  |   SET_DICT: (state, { key, value }) => { | ||||||
|  |     if (key !== null && key !== "") { | ||||||
|  |       state.dict.push({ | ||||||
|  |         key: key, | ||||||
|  |         value: value | ||||||
|  |       }) | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   REMOVE_DICT: (state, key) => { | ||||||
|  |     try { | ||||||
|  |       for (let i = 0; i < state.dict.length; i++) { | ||||||
|  |         if (state.dict[i].key == key) { | ||||||
|  |           state.dict.splice(i, i) | ||||||
|  |           return true | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } catch (e) { | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   CLEAN_DICT: (state) => { | ||||||
|  |     state.dict = new Array() | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | const actions = { | ||||||
|  |   // 设置字典 | ||||||
|  |   setDict({ commit }, data) { | ||||||
|  |     commit('SET_DICT', data) | ||||||
|  |   }, | ||||||
|  |   // 删除字典 | ||||||
|  |   removeDict({ commit }, key) { | ||||||
|  |     commit('REMOVE_DICT', key) | ||||||
|  |   }, | ||||||
|  |   // 清空字典 | ||||||
|  |   cleanDict({ commit }) { | ||||||
|  |     commit('CLEAN_DICT') | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | export default { | ||||||
|  |   namespaced: true, | ||||||
|  |   state, | ||||||
|  |   mutations, | ||||||
|  |   actions | ||||||
|  | } | ||||||
|  |  | ||||||
| @@ -364,12 +364,14 @@ export default { | |||||||
|         if (valid) { |         if (valid) { | ||||||
|           if (this.form.dictCode != undefined) { |           if (this.form.dictCode != undefined) { | ||||||
|             updateData(this.form).then(response => { |             updateData(this.form).then(response => { | ||||||
|  |               this.$store.dispatch('dict/removeDict', this.queryParams.dictType); | ||||||
|               this.$modal.msgSuccess("修改成功"); |               this.$modal.msgSuccess("修改成功"); | ||||||
|               this.open = false; |               this.open = false; | ||||||
|               this.getList(); |               this.getList(); | ||||||
|             }); |             }); | ||||||
|           } else { |           } else { | ||||||
|             addData(this.form).then(response => { |             addData(this.form).then(response => { | ||||||
|  |               this.$store.dispatch('dict/removeDict', this.queryParams.dictType); | ||||||
|               this.$modal.msgSuccess("新增成功"); |               this.$modal.msgSuccess("新增成功"); | ||||||
|               this.open = false; |               this.open = false; | ||||||
|               this.getList(); |               this.getList(); | ||||||
| @@ -386,6 +388,7 @@ export default { | |||||||
|       }).then(() => { |       }).then(() => { | ||||||
|         this.getList(); |         this.getList(); | ||||||
|         this.$modal.msgSuccess("删除成功"); |         this.$modal.msgSuccess("删除成功"); | ||||||
|  |         this.$store.dispatch('dict/removeDict', this.queryParams.dictType); | ||||||
|       }).catch(() => {}); |       }).catch(() => {}); | ||||||
|     }, |     }, | ||||||
|     /** 导出按钮操作 */ |     /** 导出按钮操作 */ | ||||||
|   | |||||||
| @@ -339,6 +339,7 @@ export default { | |||||||
|     handleRefreshCache() { |     handleRefreshCache() { | ||||||
|       refreshCache().then(() => { |       refreshCache().then(() => { | ||||||
|         this.$modal.msgSuccess("刷新成功"); |         this.$modal.msgSuccess("刷新成功"); | ||||||
|  |         this.$store.dispatch('dict/cleanDict'); | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user