De Vuex a Pinia. Cómo migrar una aplicación existente

Rate this content
Bookmark

¿Estás perdiendo la cabeza intentando convertir tu tienda Vuex a Pinia? Aquí tienes una guía paso a paso sobre cómo migrar las definiciones de tienda y las pruebas, de manera fácil y sin sufrimiento.

FAQ

Pinia es la biblioteca oficialmente reconocida para la gestión de estado en Vue.js, diseñada para trabajar con la API de composición y simplificar la gestión de estado en comparación con Vuex, especialmente en la transición de Vue.js 2 a Vue.js 3.

Sí, Pinia puede coexistir con Vuex. Esto permite una migración gradual de Vuex a Pinia, facilitando la transición sin necesidad de reescribir todo el manejo de estado de una sola vez.

Para instalar Pinia, simplemente usa el comando 'npm install pinia' o 'yarn add pinia'. Si estás utilizando Vue.js 2.6, también necesitas instalar la Vue Composition API.

Pinia ofrece una API más sencilla sin mutaciones, lo que reduce la verbosidad. Las tiendas son dinámicas por defecto, eliminando la necesidad de añadir tiendas dinámicamente y no requiere envoltorios complejos para soportar TypeScript, facilitando su uso y mantenimiento.

En Pinia, defines una tienda usando la función 'defineStore', donde pasas un identificador único y una función para el estado, junto con getters y acciones. Esto elimina la necesidad de mutaciones y simplifica la gestión del estado.

Para migrar de Vuex a Pinia, cambia la inicialización de la tienda y utiliza 'defineStore' en lugar de 'createStore'. Elimina las mutaciones y adapta los getters y acciones para usar el contexto 'this' en lugar de pasar el estado y getters como argumentos.

Para usar una tienda Pinia en componentes Vue, importa la tienda usando 'useStore' desde el archivo de tienda y accede a sus estados, getters y acciones directamente. Esto simplifica la interacción con el estado comparado con Vuex.

Sí, Pinia tiene soporte integrado para TypeScript, proporcionando auto-completación y tipos seguros sin la necesidad de configuraciones adicionales, lo que mejora la experiencia de desarrollo y mantiene el código más limpio y fácil de mantener.

Denny Biasiolli
Denny Biasiolli
24 min
15 May, 2023

Comments

Sign in or register to post your comment.

Video Summary and Transcription

Pinia es la biblioteca oficialmente reconocida para la gestión de estados en Vue.js, con una API más sencilla que Vuex y soporte para TypeScript. Migrar a Pinia implica crear una tienda raíz, definir tiendas y usar store2refs o el uso exportado de la tienda en los componentes. Probar el comportamiento real de la tienda requiere crear una instancia de Pinia, mientras que las pruebas de componentes implican importar useStore y usar mapState y mapAction de vigname. La migración de pruebas implica crear una vista local y usar el plugin de Pinia, y Vuex y Pinia pueden coexistir pero deben ser migrados módulo por módulo. La persistencia de la tienda se puede lograr suscribiéndose a los cambios de la tienda o utilizando un observador.

1. Introducción a Pinia

Short description:

Pinia es la biblioteca oficialmente reconocida para la gestión de estado en Vue.js. Tiene una API más sencilla que VueX, no necesita mutaciones y soporta TypeScript sin envoltorios complejos. Pina puede coexistir con Vuex.

Hola, ¿estás listo para migrar tus proyectos de UX a Pinia? Bueno, empecemos juntos.

Hola, soy Danny, soy de Italia. Soy un desarrollador full stack que trabaja con Python y JavaScript, y por supuesto, Vue.js. Y trabajo para Fingerprint como desarrollador front-end.

Entonces, comencemos hablando de Pinia. ¿Qué es Pinia? Bueno, Pinia es la biblioteca oficialmente reconocida para la gestión de estado en Vue.js. Pinia comenzó como un experimento para rediseñar cómo podría ser una tienda para Vue.js con API de composición. Y por supuesto, intentaron implementar ideas y muchas cosas del equipo central de discusión para VueX5. Y luego vieron que ya estaba allí. Entonces, ¿por qué aplicar de nuevo, los mismos cambios a Vuex para crear VueX5, cuando PNIA ya estaba allí. Así que vamos a darle a PNIA y hacerlo la recomendación predeterminada ahora.

Entonces, antes de comenzar a migrar todo, hagamos una rápida comparación entre VueX y PNIA. Por supuesto, PNIA funciona con Vue.js 2 y 3 con la misma versión instalada. Así que no necesitas instalar, por ejemplo, VueX 3 para Vue.js 2 y VueX 4 para Vue.js 3. Solo necesitas instalar la última PNIA disponible. Y por supuesto que funciona. Y aparte de esto, tiene una API más sencilla que VueX porque las mutaciones ya no existen. A menudo se percibían como extremadamente verbosas. Y de nuevo, con cadenas mágicas para inyectar y así sucesivamente, eran un poco difíciles de usar. Así que no necesitas mutaciones ahora, solo acciones, pero lo veremos en un momento. Y luego no necesitas crear envoltorios complejos personalizados para soportar TypeScript porque, por supuesto, está, de nuevo, siempre implementado como una función o como un objeto. Así que es perfecto con la auto-completación y así sucesivamente. Así que no más cadenas mágicas para inyectar, importar funciones, importar métodos y propiedades, llamarlos y disfrutar de la completación. Y no necesitas añadir tiendas de forma dinámica porque todas son dinámicas por defecto. Es genial. Por la misma razón, no necesitas anidar módulos y no necesitas crear una estructura anidada para tu tienda porque son como con espacios de nombres, puedes decir. Y puedes usar una tienda dentro de otra y funciona. Simplemente genial.

Entonces, comencemos instalando Pina. Pina puede coexistir con Vuex, así que puedes instalarlos juntos.

2. Migrando a Pinia y Estructura de la Tienda Vuex

Short description:

Si estás utilizando Vue.js 3 o 2.7, puedes simplemente instalar Pina. Si estás utilizando Vue.js 2.6, necesitas instalar también Vue composition API. Para crear la tienda raíz, importa create Pina y úsalo en tu aplicación. Para una tienda raíz avanzada, crea un archivo index.js en el directorio de tiendas. Define al menos una tienda utilizando la sintaxis proporcionada. Recuerda devolver propiedades, getters y acciones en la parte inferior de la función. Para usar la tienda en componentes, importa store2refs o la tienda de uso exportada. Para Vue.js 2, importa mapState y mapActions. Ahora, preparemos la migración examinando la estructura de la tienda Vuex.

Si estás utilizando Vue.js 3 o 2.7, puedes simplemente instalar Pina. Eso es todo, pero si estás utilizando Vue.js 2.6, necesitas instalar también Vue composition API porque Pina funciona con composition API. Entonces puedes encontrar una tienda raíz de una manera básica. Así que simplemente importando create Pina y usándolo en tu aplicación. O si estás utilizando Vue.js 2.x, necesitas importar también el plugin Pina Vue y usar el plugin antes de crear Pina. Pero si quieres crear la tienda raíz de una manera avanzada, necesitas crear un archivo index.js en el directorio de tiendas, importando create Pina y creando la tienda. Algo similar para Vue.js 2.x. Y luego en tu archivo main.js, puedes importar tu Pina desde tiendas y usarlo en tu aplicación. Así que, todo lo relacionado con Pina permanecerá en la carpeta de tiendas.

Luego, después de definir la tienda raíz, llamémosla la instancia Pina, necesitas definir al menos una tienda si quieres usar una tienda. Así que, esta es la sintaxis para Vue.js 3.x y 2.x también. Así que, necesitas definir la tienda pasando el nombre de la tienda como primer parámetro, y necesita ser único entre las tiendas. Y como segundo parámetro, necesitas pasar el estado, que es una función que devuelve un objeto. Y luego getters y acciones, por supuesto sin mutaciones, acciones por supuesto, sin mutaciones, pero acciones que cambian el estado de la tienda usando solo esto. Puedes usar una sintaxis de composition API también. Es algo similar al script de configuración, pero lo importante que debes recordar es que necesitas devolver propiedades, getters y acciones en la parte inferior de la función, de lo contrario no funcionará. Pero si recuerdas esto, puedes simplemente definir tus propiedades reactivas, computadas y funciones, y funciona. Es realmente genial.

Ahora, para usar la tienda en tus componentes, necesitas importar store2refs. Store2refs si quieres usar la sintaxis aquí, o simplemente importando la tienda, tu tienda de uso exportada, luego declarando la tienda. Y a partir de ahora puedes usar directamente la tienda, accediendo a las acciones de estado y getters desde aquí. O si quieres usar getters y propiedades reactivas de una manera fácil con variables, puedes definirlas usando una sintaxis computada como esta o como mencioné hace unos segundos, puedes usar store2refs para expandirlas en variables en una sola línea. No necesitas store2refs para acciones porque son funciones simples. Así que puedes llamarlas sin la reactividad. Para Vue.js 2, necesitas importar mapState y mapActions algo similar a Vuex y por supuesto, tu tienda y luego puedes mapear el estado y las acciones para envolver los getters de estado en mapState y acciones, mapActions, por supuesto. Y puedes usar cadenas como lo estábamos haciendo en Vuex en Vuex o puedes mapearlos de esta manera.

Así que ahora es el momento de migrar todo de Vuex a Binia. Pero antes de eso, necesitamos preparar la migración para tener todo ordenado y todo listo para ir. Así que echemos un vistazo a la estructura de la tienda Vuex. Tenemos la tienda con index.js conteniendo la inicialización de Vuex, Importa modules, y la tienda principal y otros modules.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Solicitudes de Red con Cypress
TestJS Summit 2021TestJS Summit 2021
33 min
Solicitudes de Red con Cypress
Top Content
Ya sea que estés probando tu UI o API, Cypress te proporciona todas las herramientas necesarias para trabajar y gestionar solicitudes de red. Esta tarea de nivel intermedio demuestra cómo usar los comandos cy.request y cy.intercept para ejecutar, espiar y simular solicitudes de red mientras pruebas tu aplicación en el navegador. Aprende cómo funcionan los comandos, así como los casos de uso para cada uno, incluyendo las mejores prácticas para probar y simular tus solicitudes de red.
Testing Pyramid Makes Little Sense, What We Can Use Instead
TestJS Summit 2021TestJS Summit 2021
38 min
Testing Pyramid Makes Little Sense, What We Can Use Instead
Top Content
Featured Video
Gleb Bahmutov
Roman Sandler
2 authors
The testing pyramid - the canonical shape of tests that defined what types of tests we need to write to make sure the app works - is ... obsolete. In this presentation, Roman Sandler and Gleb Bahmutov argue what the testing shape works better for today's web applications.
Pruebas de ciclo completo con Cypress
TestJS Summit 2022TestJS Summit 2022
27 min
Pruebas de ciclo completo con Cypress
Top Content
Cypress ha tomado al mundo por sorpresa al traer una herramienta fácil de usar para pruebas de extremo a extremo. Sus capacidades han demostrado ser útiles para crear pruebas estables para aplicaciones de frontend. Pero las pruebas de extremo a extremo son solo una pequeña parte de los esfuerzos de prueba. ¿Qué pasa con tu API? ¿Qué pasa con tus componentes? Bueno, en mi charla me gustaría mostrarte cómo podemos comenzar con pruebas de extremo a extremo, profundizar con pruebas de componentes y luego subir a probar nuestra API, circ
Desarrollo Efectivo de Pruebas
TestJS Summit 2021TestJS Summit 2021
31 min
Desarrollo Efectivo de Pruebas
Top Content
Los desarrolladores quieren dormir tranquilos sabiendo que no rompieron la producción. Las empresas quieren ser eficientes para satisfacer las necesidades de sus clientes más rápido y obtener una ventaja competitiva antes. TODOS queremos ser coste efectivos... o debería decir... ¡PRUEBA EFECTIVA!¿Pero cómo hacemos eso?¿Nos sirve bien la terminología de "unidad" e "integración"?¿O es hora de un cambio? ¿Cuándo deberíamos usar cada estrategia para maximizar nuestra "efectividad de prueba"?¡En esta charla te mostraré una nueva forma de pensar sobre las pruebas coste efectivas con nuevas estrategias y nuevos términos de prueba!¡Es hora de ir MÁS PROFUNDO!
Playwright Test Runner
TestJS Summit 2021TestJS Summit 2021
25 min
Playwright Test Runner
Top Content
Todos pueden escribir pruebas fácilmente
TestJS Summit 2023TestJS Summit 2023
21 min
Todos pueden escribir pruebas fácilmente
Echemos un vistazo a cómo Playwright puede ayudarte a escribir tus pruebas de extremo a extremo con herramientas como Codegen que generan pruebas basadas en la interacción del usuario. Exploraremos el modo UI para una mejor experiencia de desarrollador y luego repasaremos algunos consejos para asegurarnos de que no tengas pruebas inestables. Luego hablemos de cómo poner en marcha tus pruebas en CI, depurar en CI y escalar usando fragmentos.

Workshops on related topic

Diseñando Pruebas Efectivas con la Biblioteca de Pruebas de React
React Summit 2023React Summit 2023
151 min
Diseñando Pruebas Efectivas con la Biblioteca de Pruebas de React
Top Content
Featured Workshop
Josh Justice
Josh Justice
La Biblioteca de Pruebas de React es un gran marco para las pruebas de componentes de React porque responde muchas preguntas por ti, por lo que no necesitas preocuparte por esas preguntas. Pero eso no significa que las pruebas sean fáciles. Todavía hay muchas preguntas que tienes que resolver por ti mismo: ¿Cuántas pruebas de componentes debes escribir vs pruebas de extremo a extremo o pruebas de unidad de nivel inferior? ¿Cómo puedes probar una cierta línea de código que es difícil de probar? ¿Y qué se supone que debes hacer con esa persistente advertencia de act()?
En esta masterclass de tres horas, presentaremos la Biblioteca de Pruebas de React junto con un modelo mental de cómo pensar en el diseño de tus pruebas de componentes. Este modelo mental te ayudará a ver cómo probar cada bit de lógica, si debes o no simular dependencias, y ayudará a mejorar el diseño de tus componentes. Te irás con las herramientas, técnicas y principios que necesitas para implementar pruebas de componentes de bajo costo y alto valor.
Tabla de contenidos- Los diferentes tipos de pruebas de aplicaciones de React, y dónde encajan las pruebas de componentes- Un modelo mental para pensar en las entradas y salidas de los componentes que pruebas- Opciones para seleccionar elementos DOM para verificar e interactuar con ellos- El valor de los mocks y por qué no deben evitarse- Los desafíos con la asincronía en las pruebas de RTL y cómo manejarlos
Requisitos previos- Familiaridad con la construcción de aplicaciones con React- Experiencia básica escribiendo pruebas automatizadas con Jest u otro marco de pruebas unitarias- No necesitas ninguna experiencia con la Biblioteca de Pruebas de React- Configuración de la máquina: Node LTS, Yarn
Cómo empezar con Cypress
TestJS Summit 2022TestJS Summit 2022
146 min
Cómo empezar con Cypress
Featured WorkshopFree
Filip Hric
Filip Hric
La web ha evolucionado. Finalmente, también lo ha hecho el testing. Cypress es una herramienta de testing moderna que responde a las necesidades de testing de las aplicaciones web modernas. Ha ganado mucha popularidad en los últimos años, obteniendo reconocimiento a nivel mundial. Si has estado esperando aprender Cypress, ¡no esperes más! Filip Hric te guiará a través de los primeros pasos sobre cómo empezar a usar Cypress y configurar tu propio proyecto. La buena noticia es que aprender Cypress es increíblemente fácil. Escribirás tu primer test en poco tiempo y luego descubrirás cómo escribir un test de extremo a extremo completo para una aplicación web moderna. Aprenderás conceptos fundamentales como la capacidad de reintentar. Descubre cómo trabajar e interactuar con tu aplicación y aprende cómo combinar pruebas de API y de UI. A lo largo de todo este masterclass, escribiremos código y realizaremos ejercicios prácticos. Saldrás con una experiencia práctica que podrás aplicar a tu propio proyecto.
Detox 101: Cómo escribir pruebas de extremo a extremo estables para su aplicación React Native
React Summit 2022React Summit 2022
117 min
Detox 101: Cómo escribir pruebas de extremo a extremo estables para su aplicación React Native
Top Content
WorkshopFree
Yevheniia Hlovatska
Yevheniia Hlovatska
A diferencia de las pruebas unitarias, las pruebas de extremo a extremo buscan interactuar con su aplicación tal como lo haría un usuario real. Y como todos sabemos, puede ser bastante desafiante. Especialmente cuando hablamos de aplicaciones móviles.
Las pruebas dependen de muchas condiciones y se consideran lentas e inestables. Por otro lado, las pruebas de extremo a extremo pueden dar la mayor confianza de que su aplicación está funcionando. Y si se hace correctamente, puede convertirse en una herramienta increíble para aumentar la velocidad del desarrollador.
Detox es un marco de pruebas de extremo a extremo en caja gris para aplicaciones móviles. Desarrollado por Wix para resolver el problema de la lentitud e inestabilidad y utilizado por React Native en sí como su herramienta de pruebas E2E.
Únete a mí en esta masterclass para aprender cómo hacer que tus pruebas de extremo a extremo móviles con Detox sean excelentes.
Prerrequisitos- iOS/Android: MacOS Catalina o más reciente- Solo Android: Linux- Instalar antes de la masterclass
Masterclass de Pruebas de API con Postman
TestJS Summit 2023TestJS Summit 2023
48 min
Masterclass de Pruebas de API con Postman
Top Content
WorkshopFree
Pooja Mistry
Pooja Mistry
En el panorama siempre en evolución del desarrollo de software, garantizar la fiabilidad y funcionalidad de las API se ha vuelto primordial. "Pruebas de API con Postman" es una masterclass completa diseñada para equipar a los participantes con los conocimientos y habilidades necesarios para sobresalir en las pruebas de API utilizando Postman, una herramienta poderosa ampliamente adoptada por profesionales en el campo. Esta masterclass profundiza en los fundamentos de las pruebas de API, avanza a técnicas de prueba avanzadas y explora la automatización, las pruebas de rendimiento y el soporte multiprotocolo, proporcionando a los asistentes una comprensión holística de las pruebas de API con Postman.
Únete a nosotros para esta masterclass para desbloquear todo el potencial de Postman para las pruebas de API, agilizar tus procesos de prueba y mejorar la calidad y fiabilidad de tu software. Ya seas un principiante o un probador experimentado, esta masterclass te equipará con las habilidades necesarias para sobresalir en las pruebas de API con Postman.
Pruebas de Aplicaciones Web utilizando Cypress
TestJS Summit - January, 2021TestJS Summit - January, 2021
173 min
Pruebas de Aplicaciones Web utilizando Cypress
WorkshopFree
Gleb Bahmutov
Gleb Bahmutov
Este masterclass te enseñará los conceptos básicos de cómo escribir pruebas de extremo a extremo utilizando Cypress Test Runner.
Cubriremos la escritura de pruebas, abarcando todas las características de la aplicación, estructurando las pruebas, interceptando solicitudes de red y configurando los datos del backend.
Cualquier persona que conozca el lenguaje de programación JavaScript y tenga NPM instalado podrá seguir el masterclass.
Mejores Prácticas para Escribir y Depurar Pruebas de Cypress
TestJS Summit 2023TestJS Summit 2023
148 min
Mejores Prácticas para Escribir y Depurar Pruebas de Cypress
Workshop
Filip Hric
Filip Hric
Probablemente conozcas la historia. Has creado un par de pruebas y, como estás utilizando Cypress, lo has hecho bastante rápido. Parece que nada te detiene, pero luego - prueba fallida. No fue la aplicación, no fue un error, la prueba fue... ¿inestable? Bueno sí. El diseño de la prueba es importante sin importar la herramienta que utilices, incluyendo Cypress. La buena noticia es que Cypress tiene un par de herramientas bajo su cinturón que pueden ayudarte. Únete a mí en mi masterclass, donde te guiaré lejos del valle de los anti-patrones hacia los campos de pruebas estables y siempre verdes. Hablaremos sobre los errores comunes al escribir tu prueba, así como depurar y revelar problemas subyacentes. Todo con el objetivo de evitar la inestabilidad y diseñar pruebas estables.