Home > Web Front-end > Vue.js > Detailed explanation of the use of Mutation in Vuex state management

Detailed explanation of the use of Mutation in Vuex state management

藏色散人
Release: 2022-08-10 14:47:30
forward
3038 people have browsed it

mutations status update

The only way to update store status in vuex: submit Mutation

Mutation mainly consists of two parts:

  • String event type (type)

  • A callback function (handler), the callback function’s One parameter is state
    Detailed explanation of the use of Mutation in Vuex state management

##mutations passing parameters

When updating data through mutations, we may need to carry some additional parameters

Parameters are called mutations and are payloads

Example:

The first button clicks counter 5, the second button clicks counter 10

App.vue file

<button>+5</button>
<button>+10</button>
Copy after login
index.js file in store file

 mutations: {
    incrementCount(state, count) {
      state.counter += count
    }
  },
Copy after login
App.vue file

methods: {
    addCount(count) {
      this.$store.commit("incrementCount", count);
    }
  }
Copy after login
mutations submission style

Normal submission style

this.$store.commit("incrementCount", count);
Copy after login
Submit like this, if you print count, you will get count

incrementCount(state, count) {
      // state.counter += count
      console.log(count);
    }
Copy after login

Detailed explanation of the use of Mutation in Vuex state management##Special submission style

this.$store.commit({
        type: "incrementCount",
        count
      });
Copy after login
Copy after login
If Print count and get an object

    incrementCount(state, count) {
      // state.counter += count
      console.log(count);
    }
Copy after login

So it is more appropriate to do this in mutations

incrementCount(state, payload) {
      state.counter += payload.count
      console.log(payload.count);
    }
Copy after login
Detailed explanation of the use of Mutation in Vuex state managementSubmit in App.vue
this.$store.commit({
        type: "incrementCount",
        count
      });
Copy after login
Copy after login

mutations response rules

The state in vuex is responsive. When the data in the state changes, the vue component will automatically update.

When we change the value in the original object, the page will also change

state: {
    info: {
      name: 2401,
      age: 18
    }
  },
   mutations: {
    // 改变info中的值
    infoChange(state) {
      state.info.age = 10
    }
  },
Copy after login
In App.vue

<h2>{{$store.state.info}}</h2>
<button>infoChange</button>
Copy after login
 infoChange() {
      this.$store.commit("infoChange");
    }
Copy after login

Detailed explanation of the use of Mutation in Vuex state management
Detailed explanation of the use of Mutation in Vuex state managementAdd value to the original object

Cannot do responsive method

state.info['address'] = '地球';
Copy after login
In fact, the address has been It was added to info, but this method cannot be responsive, so it is not displayed on the page

Responsive methodDetailed explanation of the use of Mutation in Vuex state management

Vue.set(state.info, "address", '地球');
Copy after login

## Delete the value in the original objectDetailed explanation of the use of Mutation in Vuex state management
Can't do the responsive method

delete state.info.age;
Copy after login
In fact, the age in the info has been deleted, but this method can't do it to responsive, so there are age


responsive methodsDetailed explanation of the use of Mutation in Vuex state management

Vue.delete(state.info, "age")
Copy after login

mutations constant typeDetailed explanation of the use of Mutation in Vuex state management

Official recommendation is to define the method names in mutations as constants, which is less error-prone and easier to manage and maintain.

Create mutations-type.js file under the store file to store constants

export const INCREMENT = "increment"
export const DECREMENT = "decrement"
Copy after login
Import and use it in the index.js file under the store file

import {
  INCREMENT,
  DECREMENT
} from "../store/mutations-type"
Copy after login
 mutations: {
    [INCREMENT](state) {
      state.counter++;
    },
    [DECREMENT](state) {
      state.counter--;
    },
  }
Copy after login
Import and use it in the App.vue file

import { INCREMENT, DECREMENT } from "../src/store/mutations-type";
Copy after login
methods: {
    add() {
      this.$store.commit(INCREMENT);
    },
    sub() {
      this.$store.commit(DECREMENT);
    },
   }
Copy after login
[Related recommendations:

vue.js video tutorial

The above is the detailed content of Detailed explanation of the use of Mutation in Vuex state management. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:csdn.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template