Share to: share facebook share twitter share wa share telegram print page

 

Vuex

Vuex
Original author(s)Evan Yue
Initial releaseNovember 2016; 8 years ago (2016-11)
Stable release
4.0.2 / June 17, 2021
Repositorygithub.com/vuejs/vuex
Written inJavaScript
PlatformWeb platform
PredecessorVuex
Size508 KB
TypeState management library
LicenseMIT License
Websitevuex.vuejs.org

Vuex is an open-source state management library for Vue.js applications and a JavaScript framework. It was created by Evan You, the developer behind Vue.js, to provide a centralized store for managing state in Vue.js applications, making it easier to handle and synchronize data across components.[1]

Overview

Since Vuex follows a unidirectional data flow pattern, data flows in one direction throughout the application.[2]

In Vuex, application states are stored in a single store—a JavaScript object. Each component in the application can access the store and update its state, while the store itself may only be modified by committing mutations. Mutations are functions that can change the state of the store and must always be synchronous in nature.[3]

Actions are asynchronous functions that not only commit mutations but also perform other operations, including API calls. They are used to handle complex logic and can be called from components or other actions.[4]

Getters, on the other hand, are functions that enable components to access and manipulate the state of the store without modifying it. They can be used to derive values from the state or filter the data.[5]

History

Vuex's history begins with the creation of Vue.js, a progressive JavaScript framework developed by Evan You. Vue.js was first released in February 2014. It gained popularity quickly due to its simplicity and performance.

As Vue.js applications grew in complexity, there arose a need for effective state management. Developers wanted a solution to manage and synchronize the state of components in a Vue.js application.

Evan You, the creator of Vue.js, recognized this need and decided to build a dedicated state management library that would seamlessly integrate with Vue.js. This library later became known as Vuex.

Vuex was officially introduced in March 2015. Its goal was to provide a centralized and predictable way to manage application state in Vue.js applications.[6]

Features

Centralized state management

Vuex allows for the centralized management of an application's state, theoretically making it easier to maintain and update.[7]

Predictable state changes

Since mutations are synchronous, and actions are asynchronous in nature, state changes in an application are predictable and easier to debug.[8]

Focus on performance

Vuex reduces the amount of duplicated code in an application, which can often improve its performance.[9]

Simplified communication between components

Since each component has access to the same store, communication between them is also simplified.[10]

Future

In terms of future development, the Vuex team has been working on enhancing the library and recently released Vuex 4. This version brings improved TypeScript support, enhanced debugging tools, and better performance. The team has also been working on adding support for server-side rendering and introducing a new composition API, which will reportedly make it easier to use Vuex with Vue.js in the future.[11][timeframe?]

Pinia is another state management library for Vue.js applications that has called the future of Vuex into question. Released in 2019, like Vuex, it provides a centralized store for managing the state of an application. However, this differs from Vuex in several ways. First, Pinia uses a more modern API and is able to leverage the capabilities of the Composition API in Vue.js 3. Pinia has a smaller codebase and different structure compared to Vuex, which some developers find easier to understand, particularly those new to state management in Vue.js. As a result of these advantages, Pinia is gaining considerable popularity in the Vue.js community and has replaced Vuex in many ways as the preferred state management library for Vue.js projects. Nevertheless, Vuex still benefits from a large user base and remains widely used in existing Vue.js applications.[12]

See also

References

  1. ^ "What is Vuex? | Vuex". vuex.vuejs.org. Retrieved 2024-02-14.
  2. ^ "Understanding Unidirectional Data Flow - Vue - The Complete Guide (Including Vue Router, Vuex, and Composition API) [Video]". www.oreilly.com. Retrieved 2023-03-27.
  3. ^ "Getting Started with Storing Vue Data in Vuex". Fjolt. Retrieved 2023-03-31.
  4. ^ "How to query your API using Vuex in your Vue application". DEV Community. 12 November 2019. Retrieved 2023-03-31.
  5. ^ "When To Use Vuex Getters In a Vue.js Project". www.drewtown.dev. 27 August 2019. Retrieved 2023-03-31.
  6. ^ "Between the Wires interview with Evan You - Between the Wires". 2017-06-03. Archived from the original on 2017-06-03. Retrieved 2023-03-27.
  7. ^ "Vuex: State Management Simplified in Vue.js". www.codemag.com. Retrieved 2023-03-31.
  8. ^ "Reactive And Simple State Management With Vuex". GeekyAnts Tech Blog. 17 May 2022. Retrieved 2023-03-31.
  9. ^ "When To Use Vuex Getters In a Vue.js Project". www.drewtown.dev. 27 August 2019. Retrieved 2023-03-31.
  10. ^ Ago, Alfarisi94in #utopian-Io • 5 Years (2017-12-27). "How Communicating Between Components With Vuex, State Management From Vue". Steemit. Retrieved 2023-03-31.{{cite web}}: CS1 maint: numeric names: authors list (link)
  11. ^ "What's Coming To VueX?". Smashing Magazine. 2020-12-24. Retrieved 2023-03-31.
  12. ^ Kotov, Oleksandr (2023-01-11). "Pinia vs Vuex: Farewell Vuex, Hello Pinia! How to Get Started? - SPG Blog - Web Applications Development". Software Planet Group. Retrieved 2023-03-27.
Kembali kehalaman sebelumnya


Index: pl ar de en es fr it arz nl ja pt ceb sv uk vi war zh ru af ast az bg zh-min-nan bn be ca cs cy da et el eo eu fa gl ko hi hr id he ka la lv lt hu mk ms min no nn ce uz kk ro simple sk sl sr sh fi ta tt th tg azb tr ur zh-yue hy my ace als am an hyw ban bjn map-bms ba be-tarask bcl bpy bar bs br cv nv eml hif fo fy ga gd gu hak ha hsb io ig ilo ia ie os is jv kn ht ku ckb ky mrj lb lij li lmo mai mg ml zh-classical mr xmf mzn cdo mn nap new ne frr oc mhr or as pa pnb ps pms nds crh qu sa sah sco sq scn si sd szl su sw tl shn te bug vec vo wa wuu yi yo diq bat-smg zu lad kbd ang smn ab roa-rup frp arc gn av ay bh bi bo bxr cbk-zam co za dag ary se pdc dv dsb myv ext fur gv gag inh ki glk gan guw xal haw rw kbp pam csb kw km kv koi kg gom ks gcr lo lbe ltg lez nia ln jbo lg mt mi tw mwl mdf mnw nqo fj nah na nds-nl nrm nov om pi pag pap pfl pcd krc kaa ksh rm rue sm sat sc trv stq nso sn cu so srn kab roa-tara tet tpi to chr tum tk tyv udm ug vep fiu-vro vls wo xh zea ty ak bm ch ny ee ff got iu ik kl mad cr pih ami pwn pnt dz rmy rn sg st tn ss ti din chy ts kcg ve 
Prefix: a b c d e f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9