Maison >interface Web >js tutoriel >Déclaration sur les fonctions de support d'état dans Vuex@2.3.0

Déclaration sur les fonctions de support d'état dans Vuex@2.3.0

不言
不言original
2018-06-29 16:51:361533parcourir

Cet article présente principalement la déclaration de la fonction de support d'état dans Vuex@2.3.0. Le contenu est assez bon, je vais le partager avec vous maintenant et le donner comme référence.

Notes de version pour vuex 2.3.0 : les modules peuvent désormais déclarer un état à l'aide d'une fonction - cela permet de réutiliser la même définition de module (par exemple plusieurs fois dans le même magasin ou dans plusieurs magasins)

Si votre module Vuex a plusieurs formats exactement identiques, vous pouvez rendre ce module public et le référencer dans l'instance Vuex, par exemple :

import api from '~api'

const actions = {
  async ['get']({commit, rootState: {route: { path }}}, config = {}) {
    const { data: { code, data } } = await api.post(config.url, config.data)
    if (code === 1001) commit('receive', data)
  }
}

const mutations = {
  ['receive'](state, data) {
    state.data = [].concat(data)
  },
  ['modify'](state, payload) {
    const index = state.data.findIndex(item => item.id === payload.id)
    if (index > -1) {
      state.data.splice(index, 1, payload)
    }
  },
  ['insert'](state, payload) {
    state.data = [payload].concat(state.data)
  },
  ['remove'](state, id) {
    const index = state.data.findIndex(item => item.id === id)
    state.data.splice(index, 1)
  }
}

const getters = {
  ['get'](state) {
    return state.data
  }
}
export const _actions = actions
export const _mutations = mutations
export const _getters = getters
export default {
  namespaced: true,
  actions,
  mutations,
  getters
}

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

import lists from './general/lists'

Vue.use(Vuex)

export default new Vuex.Store({
  namespaced: true,
  modules: {
    base: {
      namespaced: true,
      modules: {
        app: {...lists, state: { lists: { data: [], total: 0, current_page: 1 } }},
        platform: {...lists, state: { lists: { data: [], total: 0, current_page: 1 } }},
        product: {
          namespaced: true,
          modules: {
            category: {...lists, state: { lists: { data: [], total: 0, current_page: 1 } }},
          }
        },
        keyword: {
          namespaced: true,
          modules: {
            username: {...lists, state: { lists: { data: [], total: 0, current_page: 1 } }},
          }
        },
      }
    },
    buzz: {
      namespaced: true,
      modules: {
        shop: {...lists, state: { lists: { data: [], total: 0, current_page: 1 } }},
      }
    }
})

Mais l'état doit être défini individuellement s'il est défini directement dans les listes, l'objet d'état sera référencé et partagé dans

<.> Dans vuex@2.3.0, ce problème n'existera pas

import api from &#39;~api&#39;

const actions = {
  async [&#39;get&#39;]({commit, rootState: {route: { path }}}, config = {}) {
    const { data: { code, data } } = await api.post(config.url, config.data)
    if (code === 1001) commit(&#39;receive&#39;, data)
  }
}

const mutations = {
  [&#39;receive&#39;](state, data) {
    state.data = [].concat(data)
  },
  [&#39;modify&#39;](state, payload) {
    const index = state.data.findIndex(item => item.id === payload.id)
    if (index > -1) {
      state.data.splice(index, 1, payload)
    }
  },
  [&#39;insert&#39;](state, payload) {
    state.data = [payload].concat(state.data)
  },
  [&#39;remove&#39;](state, id) {
    const index = state.data.findIndex(item => item.id === id)
    state.data.splice(index, 1)
  }
}

const getters = {
  [&#39;get&#39;](state) {
    return state.data
  }
}
export const _actions = actions
export const _mutations = mutations
export const _getters = getters
export default {
  namespaced: true,
  state() {
    return { lists: { data: [], total: 0, current_page: 1 } }
  },
  actions,
  mutations,
  getters
}

import Vue from &#39;vue&#39;
import Vuex from &#39;vuex&#39;

import lists from &#39;./general/lists&#39;

Vue.use(Vuex)

export default new Vuex.Store({
  namespaced: true,
  modules: {
    base: {
      namespaced: true,
      modules: {
        app: lists,
        platform: lists,
        product: {
          namespaced: true,
          modules: {
            category: lists,
          }
        },
        keyword: {
          namespaced: true,
          modules: {
            username: lists,
          }
        },
      }
    },
    buzz: {
      namespaced: true,
      modules: {
        shop: lists,
      }
    }
})
Ce qui précède est tout le contenu de cet article, j'espère ce sera utile pour l'apprentissage de tout le monde Aide, veuillez faire attention au site Web PHP chinois pour plus de contenu connexe !

Recommandations associées :

Accès au sous-composant VUEJS 2.0/composant parent d'appel

À propos de la méthode de mise en cache Vue2 SSR Données API

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn