Getters

Às vezes, talvez precisemos calcular o estado derivado com base no estado do store, por exemplo, filtrar através de uma lista de itens e contá-los:

computed: { doneTodosCount () { return this.$store.state.todos.filter(todo => todo.done).length } } 

Se mais do que um componente precisa fazer uso disso, temos que duplicar a função, ou extraí-lo em um auxiliar compartilhado e importá-lo em vários lugares - ambos são menos do que o ideal.

O Vuex nos permite definir getters no store. Você pode pensar neles como dados computados para os stores. Como os dados computados, o resultado de um getter é armazenado em cache com base em suas dependências e só será reavaliado quando algumas de suas dependências forem alteradas.

Os getters receberão o estado como 1º argumento:

const store = createStore({ state: { todos: [ { id: 1, text: '...', done: true }, { id: 2, text: '...', done: false } ] }, getters: { doneTodos (state) { return state.todos.filter(todo => todo.done) } } }) 

Acesso Estilo-Propriedade

Os getters serão expostos no objeto store.getters e você acessa valores como propriedades:

store.getters.doneTodos // -> [{ id: 1, text: '...', done: true }] 

Os getters também recebem outros getters como o 2º argumento:

getters: { // ... doneTodosCount (state, getters) { return getters.doneTodos.length } } 
store.getters.doneTodosCount // -> 1 

Agora podemos usar facilmente isso dentro de qualquer componente:

computed: { doneTodosCount () { return this.$store.getters.doneTodosCount } } 

Observe que os getters acessados ​​como propriedades são armazenados em cache como parte do sistema de reatividade do Vue.

Acesso Estilo-Método

Você também pode passar argumentos para os getters retornando uma função. Isso é particularmente útil quando você deseja consultar um Array no store:

getters: { // ... getTodoById: (state) => (id) => { return state.todos.find(todo => todo.id === id) } } 
store.getters.getTodoById(2) // -> { id: 2, text: '...', done: false } 

Observe que os getters acessados ​​via métodos serão executados toda vez que você os chamar, e o resultado não será armazenado em cache.

O Auxiliar mapGetters

O auxiliar mapGetters simplesmente mapeia os getters do store para os dados computados locais:

import { mapGetters } from 'vuex' export default { // ... computed: { // mistura os getters nos dados computatos com o operador spread ...mapGetters([ 'doneTodosCount', 'anotherGetter', // ... ]) } } 

Se você deseja mapear um getter com um nome diferente, use um objeto:

...mapGetters({ // mapeia `this.doneCount` para `this.$store.getters.doneTodosCount` doneCount: 'doneTodosCount' })