DEV Community

Cover image for Devo usar Composition API como substituto do VueX?
Daywison Silva
Daywison Silva

Posted on

Devo usar Composition API como substituto do VueX?

No framework Vue, na sua atual versão 3, é possível utilizar a API de composição (Composition API) para lidar com possíveis cenários de repetição de código.

As funcionalidades base do framework, como funções para lidar com estado reativo, observar mudanças de estado, definição de componentes, métodos de ciclo de vida, etc., agora podem ser importadas. Dado isso, podemos declarar explicitamente o que queremos usar do framework. A abordagem é um pouco parecida com os "hooks" para quem vem do mundo do React.

Aqui vai um exemplo:

global.js

   import { reactive } from 'vue';

   const state = reactive({ count: 0 })

   const incrementCount = () => state.count++;

   export default { state, incrementCount };
Enter fullscreen mode Exit fullscreen mode

No código acima é importada uma função que vai lidar com a reatividade do objeto, que é passado como argumento contento o atributo "count". Dessa forma qualquer alteração no atributo "count", será reativo, ou seja, qualquer lugar(componente, função, etc.) que use o "count" receberá a atualização em primeira mão, porque todos os valores dentro do objeto(state) são reativos.

Com alguns novos recursos do Vue também é possível implementar funcionalidades parecidas com as da API de contexto do React. É possível agora utilizar provide / inject para trabalhar com estado global (não se limita a isso).

Agora com a nossa loja(store) configurada com o estado e a função incrementCount() que manipula um valor do estado, é necessário "prover"(provide) esse estado para toda a nossa aplicação Vue.

main.js

import { createApp } from "vue";
import global from "@/global";

const app = createApp({
  provide: {
    global
  },
  ...
}
Enter fullscreen mode Exit fullscreen mode

Agora todos os nossos componentes podem ter acesso ao estado e as funções que manipulam o mesmo, mas para isso ser possível é necessário fazer uma "injeção" do estado global no componente, para isso iremos utilizar o "inject":

MyComponent.vue

<template>
  <div>{{ global.state.count }}
  <button @click="global.incrementCount">Increment</button>
</template>
<script>
export default {
  inject: ["global"]
}
</script>
Enter fullscreen mode Exit fullscreen mode

Dessa maneira já temos um estado global simples já implementado, mas a pergunta é, substitui VueX? A resposta é, depende.

O VueX por ser um projeto, relativamente, grande e que já tem um bom tempo no ecossistema Vue foi pensado e feito somente para lidar com o estado global da aplicação, ele pode (sugerível) ser usado em aplicações que exijam um estado global mais complexo, e as motivações são as seguintes:

  • VueX conta com a extensão do Vue que facilita bastante a inspeção do estado global, lá ele lista as mutations, actions, getters, e o próprio estado global de uma forma mais amigável, as informações ficam mais acessíveis.

  • VueX conta com vários plugins famosos que podem ser úteis em vários cenários, como o "vuex-persisted" que persiste o estado global da aplicação no local storage.

Bom, entendendo quais problemas cada solução veio resolver, agora você pode escolher qual atende o cenário do seu projeto. 😀

Referências:
https://vuejsdevelopers.com/2020/10/05/composition-api-vuex/

Oldest comments (0)