Additional instructions for using getters and actions in Vuex

Additional instructions for using getters and actions in Vuex

Preliminary Notes

1.Differences between Vue2.x and Vue3.x:

  • In Vue 3.x, there are no helper functions.
  • There is no difference in other usage of Vuex.

2. Here we only expand and supplement the use of several attributes of Vuex.

Getters added

When getters are written in a submodule, the method in the getters attribute has a total of 4 parameters

getters: {
	/**
	  * Parameter description:
	  * state: represents the satate in the current module
	  * getters: represents the getters object in the current module, generally other methods of the same level * rootState: represents the satate object of the main module * rootGetters represents the getters object of the main module *
	  * The main module is - index.js */  
	getName(state, getters, rootState, rootGetters){
		// Instructions // State and getters can be called directly // rootState.Module name.Attribute name // rootGetters['module name/getters method name under this submodule']
		//Except for state, all other functions use [''], which complies with the naming convention },
	.......
}

Actions added

When actions are written in a submodule, the first parameter context object in the actions method will have 6 objects (there are other properties, but only these 6 are provided for developers to use)

definition

// actions in submodules
actions: {
	/**
	  * Parameter 1: context is an object. If the current actions are defined in a submodule, 
	  * The context will have the following 6 objects for developers to use * 
	  * 1. commit: call mutations
	  * (1). This module calls: commit('this module mutations method name', actual parameter)
	  * (2). Other modules call: commit('module name/other module's mutation method name', actual parameter, {root: true}),
	  * {root:true} fixed parameter, means to call it as the main module * 2. state: get the state of the current module
	  * 3. dispatch: call actions method * (1). This module calls: dispatch('actions method name of this module', actual parameter)
	  * (2). Calls from other modules: dispatch('module name/actions method name of other modules', null, {root: true})
	  * 4. Getters: Get the getters of the current module 
	  * 5. rootState: state under the main module
	  * 6. rootGetters: getters under the main module
	  *
	  * Parameter 2: value is the parameter passed when calling the component */
	refreshUserName(context, value){
	    setTimeout(()=>{
           store.commit('mutations method name', actual parameter value)  
       },2000)
	}
}

Call (Vue3.x)

import { useStore } from 'vuex'
setup(){
    const store = useStore()
    // store === this.$store
    store.dispatch('module name/actions method name', parameter value)
}

During development, if you want to use the above 6 objects, you must obtain the required objects through context. You can directly obtain them through deconstruction

The following is an example from the official website:

The above is the detailed content of the supplementary instructions for the use of getters and actions in Vuex. For more supplementary information on the use of getters and actions in Vuex, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Requesting data instances in vuex actions in vue
  • Detailed example of vuex actions asynchronously modifying state
  • Specific use of Vuex's actions attribute
  • Detailed explanation of the usage of Actions in vuex learning
  • Detailed tutorial on using actions in Vuex

<<:  Introduction and analysis of three Binlog formats in MySQL

>>:  Analysis of parameter transfer process of driver module in Linux

Recommend

Solution to Mysql binlog log file being too large

Table of contents 1. Related binlog configuration...

Getting Started Tutorial for Beginners ⑨: How to Build a Portal Website

Moreover, an article website built with a blog pro...

Ubuntu20.04 VNC installation and configuration implementation

VNC is a remote desktop protocol. Follow the inst...

Detailed explanation of MySQL data rows and row overflow mechanism

1. What are the formats of lines? You can see you...

Teach you how to get the pointer position in javascript

The method of obtaining the position of the point...

Summary of discussion on nginx cookie validity period

Every visit will generate Cookie in the browser, ...

Use Docker to build a Git image using the clone repository

Overview I have been using Docker for more than a...

Summary of frequently used commands for Linux file operations

0. New operation: mkdir abc #Create a new folder ...

Detailed explanation of incompatible changes of components in vue3

Table of contents Functional Components How to wr...

JavaScript to implement image preloading and lazy loading

This article shares the specific code for impleme...

Linux concurrent execution is simple, just do it this way

Concurrency Functions time for i in `grep server ...

A brief discussion on MySQL count of rows

We are all familiar with the MySQL count() functi...