Vue详细讲解Vuex状态管理的实现

Vue详细讲解Vuex状态管理的实现

什么是Vuex

Vuex是Vue.js的官方状态管理插件,它将组件之间共享的状态抽取出来,以一个全局单例模式管理,实现了在共享状态时一些问题的规避,使代码更容易理解和维护。

Vuex的状态管理机制

Vuex的状态管理机制可以从以下三个方面来解释:

State

状态是存储在Vuex store上的单一状态树,相当于Vue模板上的data。每一个Vuex应用的中央唯一数据存储中都有一个store实例,包含了所有的状态。可以通过store.state来访问。

// store.js
import Vuex from 'vuex'
import Vue from 'vue'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    count: 0
  }
})

上面的代码实现了一个简单的store,包含了一个数值型state变量count,初始值为0。

可以在组件中通过this.$store.state.count来访问该状态。

Getter

Getter就是store的计算属性,相当于Vue模板上的computed。Vuex的store中,Getter相当于从store中派生方法的概念,在通过computed派生出新的属性时,Getter也可以根据需要派生出新的状态。

Getter接受state作为其第一个参数,可以定义计算属性,Getter会缓存计算结果并告诉你何时重新计算(当依赖的状态发生变化时)。

// store.js
export default new Vuex.Store({
  state: {
    todos: [
      { id: 1, text: 'todo1', done: true },
      { id: 2, text: 'todo2', done: false }
    ]
  },
  getters: {
    doneTodos: state => {
      return state.todos.filter(todo => todo.done)
    }
  }
})

在上面的代码中,我们新定义了一个Getter,返回已完成的列表。可以在组件中通过this.$store.getters.doneTodos来访问。这样,无论todos状态如何改变,只有当done属性变化时,该Getter才会被重新计算。

Mutation

Mutation是用于修改状态的唯一方法,相当于Vue模板上的methods。Mutation改变store中的状态的唯一方法是提交mutation,mutation就像事件一样来描述发生了什么,每个mutation都有一个字符串类型的操作命名,一个回调函数和一个payload,payload是通常会被作为回调函数的入参传进来。

Mutation必须是同步的,一旦提交了mutation,我们就可以确保state已经同步完成了更新。

// store.js
export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment: (state, payload) => {
      state.count += payload.amount
    }
  },
  actions: {
    increment: ({commit}, payload) => {
      commit('increment', payload)
    }
  }
})

在上面的代码中,我们新定义了一个mutation,名为increment,可接受一些额外的参数amount,以更新count变量。

我们可以在组件中派发一个mutation,来实现该操作(假设没有开启严格模式):

// MyComponent.vue
methods: {
    increment () {
      this.$store.commit('increment', { amount: 10 })
    }
}

Action

Action是异步操作,而且可以包含任意异步操作。Action提供给你一个使用异步请求更新状态的方法,并且可以保证该过程是同步的。

Action利用mutation中commit的概念。Action通过store.dispatch方法异步的提交mutation,最终改变state状态。通常Action将服务端请求得到的数据提交给Mutation,成功处理一些业务逻辑后通过Mutation更新State中的状态。

// store.js
export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment: (state, payload) => {
      state.count += payload.amount
    }
  },
  actions: {
    incrementAsync ({commit}, payload) {
      setTimeout(() => {
        commit('increment', payload)
      }, 1000)
    }
  }
})

在上面的代码中,我们新定义了一个Action,名为incrementAsync,受到payload的委托,在1秒钟后再提交该mutation。

我们可以在组件中派发一个Action,来实现该操作(假设没有开启严格模式):

// MyComponent.vue
methods: {
    incrementAsync () {
      this.$store.dispatch('incrementAsync', { amount: 10 })
    }
}

Vuex的核心概念

Store

Store是一个容器,它包含着应用中的所有状态。一个Vuex的Store是由唯一的一个store实例来管理的。

State

State就是存储在Store中的状态数据,State机制遵循源流驱动所提出的思想——即State可以作为源流数据,而对该数据的更新只能通过Action来派发Mutation,进而同步改变State的状态。

Getter

Getter是对State的派生数据,类似于Vue模板中的computed计算属性。Getter常作为模板中computed属性的依赖源。

Mutation

Mutation是同步的改变State中数据的唯一方法。在Mutation中建议只处理简单的动作,这种处理方式可以更容易地跟踪代码的变化。Mutation通过一系列类型名来更新State中的数据。

Action

Action允许更改State的异步数据或更复杂的逻辑,使Action中包含的异步操作可以访问到State并且可以派发Mutation。同时Action的Promise也可以在组件内使用。

Module

Module允许我们将一些较大状态的数据重构为一些具有独立功能的小模块,每个Module具有自己的State、Getter、Mutation和Action。这样,即使应用的状态不断变化或者持续增加,整个代码库也能保持整洁和可维护性。

Vuex实现示例

在Vue项目中使用Vuex非常方便,以下是其中两个示例。

示例一:计数器

// store.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment: state => state.count++,
    decrement: state => state.count--
  },
  actions: {
    increment: ({ commit }) => commit('increment'),
    decrement: ({ commit }) => commit('decrement')
  }
})
<!-- Counter.vue -->
<template>
  <div>
    <h1>Count: {{$store.state.count}}</h1>
    <button @click="$store.dispatch('increment')">+1</button>
    <button @click="$store.dispatch('decrement')">-1</button>
  </div>
</template>

<script>
export default {
  name: 'Counter'
}
</script>

示例二:待办事项

// store.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    todos: [
      { id: 1, text: 'todo1', done: true },
      { id: 2, text: 'todo2', done: false }
    ]
  },
  getters: {
    doneTodos: state => {
      return state.todos.filter(todo => todo.done)
    }
  },
  mutations: {
    toggle: (state, id) => {
      const todo = state.todos.find(todo => todo.id === id)
      todo.done = !todo.done
    },
    add: (state, todo) => {
      state.todos.push(todo)
    }
  },
  actions: {
    toggle: ({commit}, id) => {
      commit('toggle', id)
    },
    add: ({commit}, text) => {
      const todo = {
        id: Date.now(),
        text,
        done: false
      }
      commit('add', todo)
    }
  }
})
<!-- TodoList.vue -->
<template>
  <div>
    <ul>
      <li v-for="todo in $store.state.todos" :key="todo.id">
        <span :class="{ done: todo.done }">{{ todo.text }}</span>
        <button @click="$store.dispatch('toggle', todo.id)">Toggle</button>
      </li>
    </ul>
    <input type="text" v-model="text">
    <button @click="$store.dispatch('add', text)">Add</button>
  </div>
</template>

<script>
export default {
  name: 'TodoList',
  data() {
    return {
      text: ''
    }
  },
  mounted() {
    console.log(this.$store.getters.doneTodos)
  }
}
</script>

<style>
  .done { text-decoration: line-through; }
</style>

结论

Vuex是Vue.js的状态管理插件,可以有效地帮助我们管理应用程序的状态,在使用中体现了源流驱动的思想、模块化的技术手段、设计模式上的优化,其实现机制基于State、Getter、Mutation和Action四个核心概念,可以帮助前端工程师更加规范化、系统化地管理自己的前端代码,提高工作效率。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Vue详细讲解Vuex状态管理的实现 - Python技术站

(0)
上一篇 3天前
下一篇 3天前

相关文章

  • vue如何根据url下载非同源文件

    我可以给你详细讲解一下vue如何根据url下载非同源文件的完整攻略: 1. axios下载文件 通过axios来下载非同源文件是常见的做法。具体操作步骤如下: 引入axios库 首先需要在vue项目中引入axios库。 import axios from ‘axios’; 下载文件 然后通过axios发起get请求,通过responseType设置返回的数据…

    Vue 2天前
    00
  • Vue中render方法的使用详解

    接下来我将详细讲解“Vue中render方法的使用详解”的完整攻略。 什么是render方法? render 方法是 Vue 2.0 中引入的一个新特性,主要作用是代替模板,通过 render 方法直接操作 DOM 元素。采用 render 方法编写组件的方式被称为函数式编程,相对于之前的声明式编程方式,具有更强的可控性和扩展性。 render方法的参数 r…

    Vue 1天前
    00
  • Vue2.5通过json文件读取数据的方法

    以下是Vue2.5通过JSON文件读取数据的完整攻略。 准备工作 首先,我们需要准备好一个存储数据的JSON文件。 比如,我们准备好了一个叫做data.json的文件,里面存储了如下数据: { "name": "Vue2.5", "version": "2.5.22", &quo…

    Vue 1天前
    00
  • 简单学习vue指令directive

    下面是关于“简单学习 Vue 指令 directive”的完整攻略。 什么是 Vue 指令 指令(Directive)是 Vue.js 模板中最常用的一项功能之一。指令以 v- 前缀作为标识,表示对于文本或者元素节点的一些操作和行为。每个指令都提供了一个相应的行为或操作,并且可以带有参数、修饰符等。 基本用法 指令可以用在 HTML 元素和组件上,用来为它们…

    Vue 3天前
    00
  • 解决vue3打包过后空白页面的情况

    如何解决Vue3打包后空白页面的问题? 当我们使用Vue 3构建一个应用并打包的时候,有可能会遇到打包之后页面空白的情况,这种问题可能由于多种因素引起,本文将通过实际研究,提供一些解决方案。 确定是否存在缺失的依赖包 在我们使用Vue 3构建一个应用时,通常会使用一些依赖包来实现某些功能。然而,在打包的过程中,这些依赖包也有可能被一并打包,如果在打包的过程中…

    Vue 2天前
    00
  • Vue动态扩展表头的表格及数据方式(数组嵌套对象)

    下面我会详细讲解“Vue动态扩展表头的表格及数据方式(数组嵌套对象)”的完整攻略。 介绍 在Vue框架中,我们经常需要用到表格组件。而有些情况下,我们需要动态扩展表格的表头,并且表格数据是数组嵌套对象的形式。这时,我们需要采用一定的技巧来实现这一功能。 实现步骤 安装依赖 首先,我们需要安装element-ui组件库,以及vue-router和axios等常…

    Vue 1天前
    00
  • vue3 reactive响应式依赖收集派发更新原理解析

    下面我将为您详细讲解“vue3 reactive响应式依赖收集派发更新原理解析”的完整攻略。 什么是Vue3的响应式依赖收集派发更新原理? Vue3的响应式依赖收集派发更新原理是Vue3中非常重要的一个概念,它是实现Vue3响应式功能的核心原理。具体来说,Vue3响应式依赖收集派发更新原理指的是:当响应式对象的属性被访问时,系统会将该属性所对应的依赖收集起来…

    Vue 2天前
    00
  • 详解解决使用axios发送json后台接收不到的问题

    下面是“详解解决使用axios发送json后台接收不到的问题”的攻略: 问题描述 使用axios发送json格式的数据请求后,后台无法正常接收数据,导致接口无法正常执行。 解决方案 1. 使用content-type头部 首先,我们需要在发送axios请求时设置content-type头部。 axios({ method: ‘post’, url: ‘/ap…

    Vue 1天前
    00
  • vue之延时刷新实例

    关于“vue之延时刷新实例”,可以采用Vue提供的$nextTick()函数来实现。 什么是$nextTick()? $nextTick()是Vue提供的一种异步更新DOM的方法,因为Vue是响应式的视图层框架,所以只有当数据更新后才能更新DOM,而有时候我们需要等到DOM更新后再进行一些操作,这时候我们就可以使用$nextTick()。 如何使用$next…

    Vue 1天前
    00
  • 基于vue-draggable 实现三级拖动排序效果

    当我们需要实现在前端页面中完成三级拖动排序效果的时候,可以使用vue-draggable组件来完成。具体实现步骤如下: 步骤一:安装vue-draggable 首先要安装vue-draggable组件: npm install vuedraggable 步骤二:定义基本结构 在Vue组件中,我们需要定义一些基本的结构,包括三个列表,两个按钮等。可以参考以下代…

    Vue 3天前
    00