鍍金池/ 問答/HTML/ vue中怎么用vuex管理異步請求,使一個事件中的所有異步請求都執(zhí)行完,再執(zhí)行下

vue中怎么用vuex管理異步請求,使一個事件中的所有異步請求都執(zhí)行完,再執(zhí)行下一步

1.我新建好一個store并希望用一個狀態(tài)值來管理一個事件:

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

// 應(yīng)用初始狀態(tài)
const state = {
    status: ''
}

// 定義所需的 mutations
const mutations = {
    REQUESTWAITING(state) {
        console.log('waiting')
        console.log(state);
        state.status='waiting';
    },
    REQUESTSUCCESS(state) {
        console.log('success')
        console.log(state);
        state.status='success';
    },
    REQUESTERROR(state){
        state.status='error';
    }
}

const getters={
     getStatus(state)  {
        return state.status
    }
}


const actions={
    requestWaiting({commit})  {
        commit('REQUESTWAITING')
    },
    requestSuccess({commit}) {
        commit('REQUESTSUCCESS')
    },

    requestError({commit}){
        commit('REQUESTERROR')
    }
}


// 創(chuàng)建 store 實例
export default new Vuex.Store({
    actions,
    getters,
    state,
    mutations
})

2:在事件中調(diào)用vuex,當進入請求之前先將state的status改為waiting,當請求執(zhí)行完后,若成功將status修改為success,失敗改為error;(這些操作都已實現(xiàn));但是當我在下述方法中獲取status值,希望通過這個值來判斷請求是否全部完成,卻沒有獲取到想要的結(jié)果,status的值獲取到的為waiting而不是請求回調(diào)之后的值;請問有什么方法可以實現(xiàn)管理異步請求,使一個事件中的所有請求都執(zhí)行完,再執(zhí)行下一步

        wFBtn_Next_fn:function(){
            wFConfig.wf_error=0;
            //這是一個注冊事件,多個父組件調(diào)用的方法都包含異步請求
            wFeventBus.$emit('wFBtn_Next_event',event);
            let status=this.$store.state.status;
            console.log('status:')
            console.log(status);


                if(status=='error'){
                    console.log('請求發(fā)送錯誤');
                    return;
                }
                if(status=='success'){
                    console.log('請求成功')
                   return;
                }
            if(status!='success'){
                console.log('請求失敗')
                return;
            }
            

clipboard.png

回答
編輯回答
裸橙

ES6中的promise就是處理異步請求的,它有一個方法,promise.all()是當所有的異步請求都成功后再執(zhí)行里面的回調(diào)函數(shù),Promise.all([p1, p2, p3]).then(() => {this.$store.dispatch('requestSuccess')})。
可以看一下阮一峰的 http://es6.ruanyifeng.com/#do...

2017年11月12日 05:54
編輯回答
雅痞

使用 Promise 加上 async/await

2018年6月18日 03:17