loading-vuex-plugin

loading vuex

Usage no npm install needed!

<script type="module">
  import loadingVuexPlugin from 'https://cdn.skypack.dev/loading-vuex-plugin';
</script>

README

loading-vuex-plugin

NPM

TODO

通过 Docker 和 travis CI 实现提交代码的同时同步到 npmjs 上

介绍

通常在调用异步请求的时候,我们会编写很多防御性代码,在请求前设置 loading: true,请求后设置 loading: false。 这样的行为多次操作后,代码冗余度高且非常不利于维护。 这也是这个插件的设计由来。

首先了解下 Vuex3.1 新增的API --- subscribeAction

subscribeAction 也可以指定订阅处理函数的被调用时机应该在一个 action 分发之前还是之后 (默认行为是之前):

store.subscribeAction({
  before: (action, state) => {
    console.log(`before action ${action.type}`)
  },
  after: (action, state) => {
    console.log(`after action ${action.type}`)
  }
})

usage

//...
import VuexLoadingPlugin from 'loading-vuex-plugin'
// ...
export default new Vuex.Store({
  plugins: [VuexLoadingPlugin(config)]
})
/*
config 可以不填, 默认值是 {namespace: 'loading'}, type: Object
*/

// vue 文件中
computed: {
  ...mapState({
    // 假设异步获取数据方法名为 getData
    loading: state => state['loading'].status['getData']
    /*
      如果修改了 config 的值,比如
      plugins: [VuexLoadingPlugin({ namespace: 'load' })]
      那么这里调用的时候就是
      loading: state => state['load'].status['getData']
    */
  })
}

注意

vuex mutation 调用顺序,可能是以下两种情况

  1. loadingfalse => 请求调用 => loadingtrue
  2. loadingfalse => loadingtrue => 请求调用

取决于开发编写请求调用的 action 是否设置为立即执行,比如

// 情形1
const actions = {
  getData(context, args) {
    return new Promise(resolve => {
      setTimeout(() => {
        getDataAPI(args).then(res => {
          context.commit('getData', res)
        })
        resolve()
      })
    })
  }
}
// 情形2
const actions = {
  async getDate(context, args) {
    await getDataAPI(args).then(res => {
      context.commit('getData', res)
    })
  }
}