Vuex - 运行 多次分派后的功能
Vuex - Run function after multiple dispatches
我正在创建一个应用程序,在某个时候我需要加载一些数据,但为了让用户看不到损坏的数据,我插入了一个加载组件。
目前我在加载中设置了 setTimeout,但在某些时候 API 响应可能需要超过 1 秒。所以我想只在所有调度完成时更新加载状态。
MainComponent.vue
beforeCreate() {
this.$store.dispatch('responsibles/fetchData')
this.$store.dispatch('events/fetchData')
this.$store.dispatch('wallets/fetchData')
// Need to run this setTimeout after all the above dispatches become completed...
setTimeout(() => {
this.loading = false
}, 1000)
}
store/modules/responsibles.js
const state = {
responsibles: []
}
const actions = {
fetchData({dispatch}) {
function getresponsibles() {
return http.get('responsibles')
}
axios.all([
getresponsibles()
]).then(axios.spread(function (responsibles) {
dispatch('setResponsibles', responsibles.data.data)
})).catch(error => console.error(error))
},
setResponsibles({commit}, responsibles) {
commit('SET_RESPONSIBLES', responsibles)
}
}
const mutations = {
SET_RESPONSIBLES(state, responsibles) {
state.responsibles = responsibles
}
}
store/modules/events.js
const state = {
events: []
}
const actions = {
fetchData({dispatch}) {
function getEvents() {
return http.get('events')
}
axios.all([
getEvents()
]).then(axios.spread(function (events) {
dispatch('setEvents', events.data.data)
})).catch(error => console.error(error))
},
setEvents({commit}, events) {
commit('SET_EVENTS', events)
}
}
const mutations = {
SET_EVENTS(state, events) {
state.events = events
}
}
store/modules/wallets.js
const state = {
wallets: []
}
const actions = {
fetchData({dispatch}) {
function getWallets() {
return http.get('wallets')
}
axios.all([
getWallets()
]).then(axios.spread(function (wallets) {
dispatch('setWallets', wallets.data.data)
})).catch(error => console.error(error))
},
setWallets({commit}, wallets) {
commit('SET_WALLETS', wallets)
}
}
const mutations = {
SET_WALLETS(state, wallets) {
state.wallets = wallets
}
}
让你的动作return
成为Axios创建的Promise
,例如
return axios.all(...
见https://vuex.vuejs.org/guide/actions.html#composing-actions
将您的调度调用包装在 Promise.all
中并等待它们全部完成
Promise.all([
this.$store.dispatch('responsibles/fetchData'),
this.$store.dispatch('events/fetchData'),
this.$store.dispatch('wallets/fetchData')
]).finally(() => {
// using "finally" so even if there are errors, it stops "loading"
this.loading = false
})
我正在创建一个应用程序,在某个时候我需要加载一些数据,但为了让用户看不到损坏的数据,我插入了一个加载组件。
目前我在加载中设置了 setTimeout,但在某些时候 API 响应可能需要超过 1 秒。所以我想只在所有调度完成时更新加载状态。
MainComponent.vue
beforeCreate() {
this.$store.dispatch('responsibles/fetchData')
this.$store.dispatch('events/fetchData')
this.$store.dispatch('wallets/fetchData')
// Need to run this setTimeout after all the above dispatches become completed...
setTimeout(() => {
this.loading = false
}, 1000)
}
store/modules/responsibles.js
const state = {
responsibles: []
}
const actions = {
fetchData({dispatch}) {
function getresponsibles() {
return http.get('responsibles')
}
axios.all([
getresponsibles()
]).then(axios.spread(function (responsibles) {
dispatch('setResponsibles', responsibles.data.data)
})).catch(error => console.error(error))
},
setResponsibles({commit}, responsibles) {
commit('SET_RESPONSIBLES', responsibles)
}
}
const mutations = {
SET_RESPONSIBLES(state, responsibles) {
state.responsibles = responsibles
}
}
store/modules/events.js
const state = {
events: []
}
const actions = {
fetchData({dispatch}) {
function getEvents() {
return http.get('events')
}
axios.all([
getEvents()
]).then(axios.spread(function (events) {
dispatch('setEvents', events.data.data)
})).catch(error => console.error(error))
},
setEvents({commit}, events) {
commit('SET_EVENTS', events)
}
}
const mutations = {
SET_EVENTS(state, events) {
state.events = events
}
}
store/modules/wallets.js
const state = {
wallets: []
}
const actions = {
fetchData({dispatch}) {
function getWallets() {
return http.get('wallets')
}
axios.all([
getWallets()
]).then(axios.spread(function (wallets) {
dispatch('setWallets', wallets.data.data)
})).catch(error => console.error(error))
},
setWallets({commit}, wallets) {
commit('SET_WALLETS', wallets)
}
}
const mutations = {
SET_WALLETS(state, wallets) {
state.wallets = wallets
}
}
让你的动作
return
成为Axios创建的Promise
,例如return axios.all(...
见https://vuex.vuejs.org/guide/actions.html#composing-actions
将您的调度调用包装在
Promise.all
中并等待它们全部完成Promise.all([ this.$store.dispatch('responsibles/fetchData'), this.$store.dispatch('events/fetchData'), this.$store.dispatch('wallets/fetchData') ]).finally(() => { // using "finally" so even if there are errors, it stops "loading" this.loading = false })