Documentation de l'API
Vuex.Store
import Vuex from 'vuex'
const store = new Vuex.Store({ ...options })
Options du constructeur de Vuex.Store
state
type :
Object | FunctionL'objet d'état racine pour le store Vuex. Plus de détails
Si vous passez une fonction qui retourne un objet, l'objet retourné est utilisé en tant qu'état racine. Ceci est utile quand vous voulez réutiliser un objet d'état surtout dans un cas de réutilisation de module. Plus de détails
mutations
type :
{ [type: string]: Function }Enregistrer les mutations sur le store. La fonction gestionnaire reçoit toujours
statecomme premier argument (sera l'état local du module si défini dans un module), et reçoit lepayloaden second argument s'il y en a un.
actions
type :
{ [type: string]: Function }Enregistrer les actions sur le store. La fonction gestionnaire reçoit un objet
contextqui expose les propriétés suivantes :{ state, // identique à `store.state`, ou à l'état local si dans des modules rootState, // identique à `store.state`, seulement dans des modules commit, // identique à `store.commit` dispatch, // identique à `store.dispatch` getters, // identique à `store.getters`, ou les accesseurs locaux dans les modules rootGetters // identique à `store.getters`, seulement dans les modules }
getters
type :
{ [key: string]: Function }Enregistrer les accesseurs sur le store. La fonction accesseur reçoit les arguments suivants :
state, // sera l'état local du module si défini dans un module. getters // identique à `store.getters`Arguments spécifiques quand défini dans un module
state, // sera l'état local du module si défini dans un module. getters, // module local getters of the current module rootState, // état global rootGetters // tous les accesseursLes accesseurs enregistrés sont exposés sur
store.getters.
modules
type :
ObjectUn objet contenant des sous-modules qui seront regroupés dans le store, sous la forme suivante :
{ key: { state, namespaced?, mutations?, actions?, getters?, modules? }, ... }Chaque module peut contenir
stateetmutations, tout comme les options racines. L'état d'un module sera attaché à l'état racine du store en utilisant la clé du module. Les mutations et accesseurs d'un module recevront seulement l'état local du module en premier argument au lieu de l'état racine, et lecontext.statedes actions du module pointeront également vers l'état local.
plugins
type :
Array<Function>Un tableau de fonctions plugins qui seront appliquées au store. Un plugin reçoit simplement le store comme seul argument et peut soit écouter les mutations (pour la persistance de données, les logs ou le débogage) ou propager des mutations (pour les données internes, c.-à-d. websockets ou observables).
strict
- type :
Boolean default:
falseForce le store Vuex en mode strict. En mode strict, toute mutation de l'état en dehors des gestionnaires de mutation lancera une erreur.
- type :
Propriétés d'instance de Vuex.Store
state
type :
ObjectL'état racine. Lecture seule.
getters
type :
ObjectExpose les accesseurs enregistrés. Lecture seule.
Méthodes d'instance de Vuex.Store
commit(type: string, payload?: any, options?: Object) | commit(mutation: Object, options?: Object)Acter une mutation.
optionspeut avoirroot: truece qui permet d'acter des mutations racines dans des modules sous espace de nom. Plus de détailsdispatch(type : string, payload?: any, options?: Object) | dispatch(action: Object, options?: Object)Propager une action. Retourne la valeur renvoyée par le gestionnaire d'action déclenché, ou une Promesse si plusieurs gestionnaires ont été déclenchés. Plus de détails
replaceState(state: Object)Remplacer l'état racine du store. Utiliser seulement pour hydrater l'état ou dans le but de voyager dans le temps.
watch(getter: Function, cb: Function, options?: Object)Observer de façon réactive la valeur de retour d'une fonction accesseur, et appeler la fonction de rappel lorsque la valeur change. L'accesseur reçoit l'état du store en premier argument, et les accesseurs en second argument. Accepte un objet optionnel d'options qui prend les mêmes options que la méthode
vm.$watchde Vue.Pour arrêter d'observer, appeler la fonction gestionnaire retournée.
subscribe(handler: Function)S'abonner aux mutations du store. Le
handlerest appelé après chaque mutation et reçoit le descripteur de mutation et l'état post mutation comme arguments :store.subscribe((mutation, state) => { console.log(mutation.type) console.log(mutation.payload) })Utilisé plus communément dans les plugins. Plus de détails
subscribeAction(handler: Function)Nouveau dans la 2.5.0+
S'abonner au actions du store. Le
handlerest appelé pour chaque action propagée et reçoit chaque description d'action et l'état du store courant en arguments :store.subscribeAction((action, state) => { console.log(action.type) console.log(action.payload) })Souvent utiliser dans les plugins. Pour plus de détails
registerModule(path: string | Array<string>, module: Module, options?: Object)Enregistrer un module dynamique. Plus de détails
optionspeut avoirpreserveState: truequi lui permet de préserver l'état précédent. Utile pour du rendu côté serveur.unregisterModule(path: string | Array<string>)Supprimer un module dynamique. Plus de détails
hotUpdate(newOptions: Object)Remplacement à la volée des nouvelles actions et mutations. Plus de détails
Fonctions utilitaires d'attachement au composant
mapState(namespace?: string, map: Array<string> | Object): ObjectCréer des propriétés calculées qui retournent le sous-arbre du store Vuex au composant. Plus de détails
Le premier argument peut être de façon optionnelle une chaine d'espace de nom. Plus de détails
mapGetters(namespace?: string, map: Array<string> | Object): ObjectCréer des propriétés calculées qui retournent la valeur calculée d'un accesseur. Plus de détails
Le premier argument peut être de façon optionnelle une chaine d'espace de nom. Plus de détails
mapActions(namespace?: string, map: Array<string> | Object): ObjectCréer des méthodes de composant qui propagent une action. Plus de détails
Le premier argument peut être de façon optionnelle une chaine d'espace de nom. Plus de détails
mapMutations(namespace?: string, map: Array<string> | Object): ObjectCréer des méthodes de composant qui actent une mutation. Plus de détails
Le premier argument peut être de façon optionnelle une chaine d'espace de nom. Plus de détails
createNamespacedHelpers(namespace: string): ObjectCréer des fonctions utilitaires liées avec espace de nom. L'objet retourné contient
mapState,mapGetters,mapActionsetmapMutationsqui sont liées à l'espace de nom fourni. Plus de détails