Home > Web Front-end > Vue.js > How to understand Mutations in Vuex? how to use?

How to understand Mutations in Vuex? how to use?

青灯夜游
Release: 2021-02-11 08:57:37
forward
3483 people have browsed it

How to understand Mutations in Vuex? how to use?

Related recommendations: "vue.js Tutorial"

The popular understanding of mutations contains a collection of methods for changing data. This is Vuex A very important point in the design is to put all logical methods for processing data in mutations to separate data and views.

How to use mutations?

Mutation structure: Each mutation has a string type event type (type) and callback function (handler), which can also be understood as {type:handler()}, which is somewhat similar to subscription publishing. Register the event first, and call handker() when the response type is triggered. When calling type, you need to use the store.commit method.

 const store = new Vuex.Store({
    state: {
        count: 1
        },
    mutations: {
   		 increment (state) {      //注册事件,type:increment,handler第一个参数是state;
  		  // 变更状态
   		state.count++}}})
   store.commit('increment')   //调用type,触发handler(state)
Copy after login

Load (payload): The simple understanding is to pass the parameter handler(stage, payload) to handler(stage); usually it is an object.

  mutations: {
 increment (state, n) {
     state.count += n}}
 store.commit('increment', 10)
Copy after login

mutation-types: Place constants in separate files to facilitate collaborative development.

mutation-types.js

export const SOME_MUTATION = 'SOME_MUTATION'
Copy after login

store.js

import Vuex from 'vuex'
import { SOME_MUTATION } from './mutation-types'
  const store = new Vuex.Store({
    state: { ... },
    mutations: {
     // 我们可以使用 ES2015 风格的计算属性命名功能来使用一个常量作为函数名
    [SOME_MUTATION] (state) {
    // mutate state
  }
}
})
Copy after login

commit: Commit can be used in components this.$store.commit('xxx') Submit mutations, or use the mapMutations auxiliary function to map the methods in the component to store.commit calls (store needs to be injected into the root node).

import { mapMutations } from 'vuex'
export default {
methods: {
  ...mapMutations([
    'increment' // 映射 this.increment() 为 this.$store.commit('increment')]),
  ...mapMutations({
    add: 'increment' // 映射 this.add() 为 this.$store.commit('increment')
  })}}
Copy after login

Source code analysis

function registerMutation (store, type, handler, path = []) {
 //4个参数,store是Store实例,type为mutation的type,handler,path为当前模块路径
    const entry = store._mutations[type] || (store._mutations[type] = 
[])  //通过type拿到对应的mutation对象数组
     entry.push(function wrappedMutationHandler (payload) {
     //将mutation包装成函数push到数组中,同时添加载荷payload参数    
     handler(getNestedState(store.state, path), payload)
     //通过getNestedState()得到当前的state,同时添加载荷payload参数
   })
 }
Copy after login

commit: call mutation

commit (type, payload, options) {
  // 3个参数,type是mutation类型,payload载荷,options配置
    if (isObject(type) && type.type) {
       // 当type为object类型,
      options = payload
      payload = type
      type = type.type
  }
 const mutation = { type, payload }
 const entry = this._mutations[type]
   // 通过type查找对应的mutation
 if (!entry) {
  //找不到报错
   console.error(`[vuex] unknown mutation type: ${type}`)
   return
 }
 this._withCommit(() => {
   entry.forEach(function commitIterator (handler) {
   // 遍历type对应的mutation对象数组,执行handle(payload)方法
   //也就是开始执行wrappedMutationHandler(handler)
     handler(payload)
   })
 })
 if (!options || !options.silent) {
   this._subscribers.forEach(sub => sub(mutation, this.state))
    //把mutation和根state作为参数传入
 }
}
Copy after login

subscribers: subscribe to store’s mutation

subscribe (fn) {
const subs = this._subscribers
if (subs.indexOf(fn) < 0) {
  subs.push(fn)
  }
return () => {
  const i = subs.indexOf(fn)
  if (i > -1) {
    subs.splice(i, 1)
    }
  }
 }
Copy after login

For more programming related knowledge, please visit:Programming Teaching! !

The above is the detailed content of How to understand Mutations in Vuex? how to use?. 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