【vue教程】六. Vue 的状态管理

news2024/9/23 13:20:56

目录

    • 往期列表
    • 本章涵盖知识点
    • 回顾
    • Vuex 的基本概念
      • 什么是 Vuex?
      • 为什么需要 Vuex?
    • Vuex 的核心概念
      • state
      • getters
      • mutations
      • actions
      • modules
    • Vuex 的安装和基本使用
      • 安装 Vuex
      • 创建 store
      • 在 Vue 应用中使用 store
      • 在组件中访问和修改状态
    • Vuex 的模块化
      • 模块化的好处
      • 创建模块
    • Vuex 的持久化
      • 持久化的好处
      • 实现持久化
    • Vuex 辅助函数
      • mapState
      • mapGetters
      • mapActions
      • mapMutations
      • 创建一个带有模块化和持久化的计数器应用
    • 结语
    • 互动交流

往期列表

  • 【vue教程】一. 环境搭建与代码规范配置
  • 【vue教程】二. Vue特性原理详解
  • 【vue教程】三. 组件复用和通信(7 种方式)
  • 【vue教程】四. Vue 计算属性和侦听器
  • 【vue教程】五. Vue 的路由管理

本章涵盖知识点

  • Vuex 的核心概念:state、getters、mutations、actions
  • Vuex 在大型应用中的作用
  • Vuex 的安装和基本使用
  • Vuex 的模块化和持久化

回顾

在第五站,我们深入学习了 Vue Router,理解了如何通过动态路由和嵌套路由来构建复杂的页面导航结构,并探讨了路由守卫在权限管理中的应用。
在这里插入图片描述

正文开始如果觉得文章对您有帮助,请帮我三连+订阅,谢谢💖💖💖


Vuex 的基本概念

什么是 Vuex?

借鉴了 Flux、Redux 和 The Elm Architecture。与其他模式不同的是,Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
状态自管理应用包含以下几个部分:

  • 状态,驱动应用的数据源;
  • 视图,以声明方式将状态映射到视图;
  • 操作,响应在视图上的用户输入导致的状态变化。

以下是一个表示“单向数据流”理念的简单示意:

flow.png

Vuex 在 Vue 组件中的流程图

vuex.png

为什么需要 Vuex?

随着应用的复杂性增加,我们需要一种更结构化的方式来管理状态,Vuex 通过集中管理状态、严格的流程变更和日志记录,使得状态管理变得简单、可预测和可维护。

Vuex 的核心概念

state

存储在 Vuex 中的状态,可以被 Vue 组件读取

getters

可以认为是 state 的计算属性,允许组件以更复杂的方式读取 state。

mutations

更改 Vuex 中状态的唯一方法是提交 mutation,它们是同步的事务

actions

类似于 mutations,但它们可以包含异步操作

modules

当应用变得复杂时,可以使用模块来将 store 分割成多个小的子 store。

Vuex 的安装和基本使用

安装 Vuex

首先,需要安装 Vuex 库:

npm install vuex --save

创建 store

创建一个新的 Vuex store:

import Vue from "vue";
import Vuex from "vuex";

Vue.use(Vuex);

const store = new Vuex.Store({
  state: {
    count: 0,
  },
  getters: {
    doubleCount: (state) => state.count * 2,
  },
  mutations: {
    increment: (state) => state.count++,
  },
  actions: {
    incrementAsync({ commit }) {
      setTimeout(() => {
        commit("increment");
      }, 1000);
    },
  },
});

在 Vue 应用中使用 store

在 main.js 中,将 store 实例注入到 Vue 中:

new Vue({
  store,
  render: (h) => h(App),
}).$mount("#app");

在组件中访问和修改状态

// 读取状态
computed: {
  doubleCount() {
    return this.$store.state.count * 2;
  }
},

// 提交mutation
methods: {
  increment() {
    this.$store.commit('increment');
  }
},

// 分发action
  incrementAsync() {
    this.$store.dispatch('incrementAsync');
  }
}

Vuex 的模块化

模块化的好处

  • 组织代码:大型应用中状态管理的逻辑可以分散到不同的文件中。
  • 命名空间:模块的 getters、actions 和 mutations 可以自动拥有命名空间。

创建模块

const moduleA = {
  namespaced: true,
  state: { ... },
  getters: { ... },
  mutations: { ... },
  actions: { ... }
};

const store = new Vuex.Store({
  modules: {
    a: moduleA
  }
});

Vuex 的持久化

持久化的好处

  • 状态恢复:在应用重新加载时恢复状态。
  • 调试:在开发过程中可以查看状态变化的历史。

实现持久化

使用localStorage或第三方库如vuex-persistedstate来实现:

npm install vuex-persistedstate
import createPersistedState from "vuex-persistedstate";

const store = new Vuex.Store({
  state: {
    count: 0,
  },
  plugins: [
    createPersistedState({
      key: "vuex",
      paths: ["count"],
    }),
  ],
});

Vuex 辅助函数

Vuex 提供了几个辅助函数,可以帮助我们更方便地在组件中使用 store 中的状态和函数。

mapState

mapState函数允许你将 store 中的 state 映射到组件的计算属性中。

import { mapState } from "vuex";

export default {
  computed: {
    ...mapState([
      // 映射 this.count 为 store.state.count
      "count",
    ]),
    // 也可以使用对象展开运算符
    ...mapState({
      // 映射 this.doubleCount 为 store.state.count * 2
      doubleCount: (state) => state.count * 2,
    }),
  },
};

mapGetters

mapGetters函数与mapState类似,但它用于映射 getters。

import { mapGetters } from "vuex";

export default {
  computed: {
    ...mapGetters([
      // 映射 this.doneCount 为 store.getters.doneTodosCount
      "doneCount",
    ]),
  },
};

mapActions

mapActions函数允许你将 actions 映射为组件的方法。

import { mapActions } from "vuex";

export default {
  methods: {
    ...mapActions([
      // 映射 this.increment() 为 store.dispatch('increment')
      "increment",
    ]),
    // 也可以使用对象展开运算符
    ...mapActions({
      // 映射 this.incrementIfOdd 为 store.dispatch('incrementIfOdd')
      incrementIfOdd: "incrementIfOdd",
    }),
  },
};

mapMutations

mapMutations函数允许你将 mutations 映射为组件的方法。

import { mapMutations } from "vuex";

export default {
  methods: {
    ...mapMutations([
      // 映射 this.increment() 为 store.commit('increment')
      "increment",
    ]),
    // 也可以使用对象展开运算符
    ...mapMutations({
      // 映射 this.setCount 为 store.commit('setCount')
      setCount: "setCount",
    }),
  },
};

创建一个带有模块化和持久化的计数器应用

  1. 创建模块化的 store

    store.js

    const moduleA = {
      namespaced: true,
      state: { count: 0 },
      mutations: {
        increment(state) {
          state.count++;
        },
      },
    };
    
    const store = new Vuex.Store({
      modules: { a: moduleA },
      plugins: [createPersistedState()],
    });
    
  2. 在 Vue 实例中使用 store

    main.js

    new Vue({
      store,
      render: (h) => h(App),
    }).$mount("#app");
    
  3. 在组件中访问模块化状态

    <!-- Component.vue -->
    <template>
      <p>{{ aCount }}</p>
      <button @click="incrementA">Increment Module A</button>
    </template>
    
    <script>
      export default {
        computed: {
          aCount() {
            return this.$store.state.a.count;
          },
        },
        methods: {
          incrementA() {
            this.$store.commit("a/increment");
          },
        },
      };
    </script>
    

结语

在本站的 Vue 探索之旅中,我们学习了 Vuex 的核心概念、模块化和持久化。通过模块化,我们可以更好地组织大型应用的状态管理逻辑;通过持久化,我们可以在应用重新加载时恢复状态。这些工具和概念将帮助我们构建更加健壮和可维护的 Vue 应用。

互动交流

欢迎在文章下方留言,分享学习 Vuex 状态管理的心得体会,或提出在学习过程中遇到的问题。我们将在后续的文章中提供解答和指导。


注意:本文内容会根据 Vue.js 和 Vuex 的最新版本进行更新,确保提供的信息是最新的。同时,为了提高文章的可读性,我们使用了清晰的代码块和图表。希望本文能够帮助你深入理解 Vue 的状态管理,并为你的 Vue 学习之旅添砖加瓦。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2053974.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PWN练习---Stack_2

目录 srop源码分析exp putsorsys源码分析exp ret2csu_1源码分析exp traveler源码分析exp srop 题源&#xff1a;[NewStarCTF 2023 公开赛道]srop 考点&#xff1a;SROP 栈迁移 源码 首先从bss段利用 syscall 调用 write 读出数据信息&#xff0c;然后调用 syscall-read向栈中…

回归预测|基于鲸鱼优化支持向量机结合Adaboost集成的数据回归预测Matlab程序 多特征输入单输出 效果非常不错!WOA-SVM-Adaboost

回归预测|基于鲸鱼优化支持向量机结合Adaboost集成的数据回归预测Matlab程序 多特征输入单输出 效果非常不错&#xff01;WOA-SVM-Adaboost 文章目录 前言回归预测|基于鲸鱼优化支持向量机结合Adaboost集成的数据回归预测Matlab程序 多特征输入单输出 效果非常不错&#xff01;…

Wallpaper-将动态壁纸永久设置为静态

可以在设置里找到横排性能选项点击之后里面有个回放&#xff0c;回放中有个应用程序规则点击设置-创建新规则&#xff0c;当explorer.exe(好像是微软的文件浏览&#xff1f;)条件为运行中&#xff0c;回放选择暂停即可 然后确定即可。

轻松上手:10款热门产品管理系统推荐

文章介绍了以下几个工具&#xff1a;PingCode、Worktile、Teambition、明道云、用友云、Tapd、禅道、Figma、Amplitude、Asana 。 在寻找合适的产品管理系统时&#xff0c;你是否感到市场上的选择令人眼花缭乱&#xff0c;不知从何选择&#xff1f;一个好的产品管理系统可以极大…

推荐4款让文字创作更轻松的AI 写作助手 !

目前很多的AI 技术已经渗透到了我们生活的各个领域&#xff0c;包括写作。ai写作工具的出现&#xff0c;为那些有写作困难或者需求的人们提供了很大的帮助&#xff0c;成为了我们的一大得力助手。今天&#xff0c;就给大家推荐几款比较热门的AI写作工具。 1、笔灵AI写作助手 直…

Java面向接口编程(例题+知识点)

题目&#xff1a; 采用面向接口编程思想组装一台计算机 计算机的主要组成部分 CPU 硬盘 内存 代码解析&#xff1a; 1.参数类型为 CPU 是因为它是一个接口。接口类型参数的主要好处是它使方法具有更好的灵活性和可扩展性。你可以传入任何实现了 CPU 接口的类的实例。 2.使用…

博达网站群管理平台 v6.0使用相关问题解决

1 介绍 最近受人所托&#xff0c;需要用博达网站群管理平台创建一个网站。该平台的内部版本为9.8.2。作为一个能直接从代码创建网站系统的人&#xff0c;初次使用本平台&#xff0c;刚开始感觉摸不着头脑。因为该平台存在的目的&#xff0c;就是让不懂代码的人能快速创建网站&…

记录xserver做域名,腾讯云做服务器的域名解析流程

以下为个人理解&#xff0c;请多指教 主域名 1.在Xserver买好域名后&#xff0c;会要求需要购买它们的服务器&#xff0c;因为server域名与server服务器是绑定关系 2.在腾讯云的“云解析DNS”添加域名&#xff0c;为自己购买的主域名abc.com 3.解析并生效 一般为www&#xff…

TransRepair

TransRepair: Context-aware Program Repair for Compilation Errors 基本信息 ASE 22: 37th IEEE/ACM International Conference on Automated Software Engineering 博客贡献人 页禾七 作者 Xueyang Li&#xff0c;Shangqing Liu&#xff0c;Ruitao Feng&#xff0c;Gu…

qt-17不规则窗体

不规则窗体 知识点shape.hshape.cppmain.cpp运行图 知识点 感觉这个就是在图片背景 贴了白色 shape.h #ifndef SHAPE_H #define SHAPE_H#include <QWidget>class Shape : public QWidget {Q_OBJECTpublic:Shape(QWidget *parent nullptr);~Shape(); protected:void m…

【开源社区】Elasticsearch(ES)中 exists 查询空值字段的坑

文章目录 1、概述2、使用 null_value 处理空值3、使用 exists 函数查询值为空的文档3.1 使用场景3.2 ES 中常见的空值查询方式3.3 常见误区3.4 使用 bool 查询函数查询空值字段3.5 exists 函数详解3.5.1 bool 查询的不足3.5.3 exists 的基本使用 3.6 完美方案 1、概述 本文主要…

环网交换机 环网数采仪 环网采集器确保数据传输无懈可击!

计讯物联Pro级双向防护&#xff0c;升级环网采集器确保数据传输无懈可击&#xff01; 在物联网(IoT)的世界里&#xff0c;数据流动如同城市交通&#xff0c;需要高效且可靠的网络来支撑。但就像城市交通可能遇到意外拥堵或道路封闭&#xff0c;传统网络在数据传输上也会遇到障…

Redis RDB三两事

rdb&#xff1a;将数据库的快照以二进制格式保存在文件中&#xff0c;redis重启后直接加载数据。可以通过save和bgsave命令生成rdb。当然我们可以在生成rdb文件时指定规则&#xff0c;例如 save 60 1000 如果60秒内不少于1000个key发生了改动&#xff0c;则生成一个新的rdb文件…

苹果电脑能玩Steam游戏吗?Steam对苹果笔记本要求高吗 steam苹果下载安装教程

对于游戏爱好者而言&#xff0c;如何在Mac上安装并使用Steam玩游戏成为一个重要的问题&#xff0c;Steam作为全球最大的数字发行平台和游戏社区&#xff0c;为玩家提供了丰富的游戏资源和社交交流平台。然而&#xff0c;由于Mac和Windows系统之间存在差异&#xff0c;很多人不确…

Linux进程间通信方式对比

参考&#xff1a; Linux进程间通信总结-百度开发者中心 Linux操作系统提供了多种进程间通信&#xff08;IPC&#xff09;的方式&#xff0c;每种方式都有其独特的应用场景和优缺点。下面将对Linux下的进程间通信方式进行总结和比较。 管道&#xff08;Pipe&#xff09; 管道是最…

小白学大模型:GLM 调用教程

最近这一两周看到不少互联网公司都已经开始秋招提前批面试了。 不同以往的是&#xff0c;当前职场环境已不再是那个双向奔赴时代了。求职者在变多&#xff0c;HC 在变少&#xff0c;岗位要求还更高了。 最近&#xff0c;我们又陆续整理了很多大厂的面试题&#xff0c;帮助一些…

计算机网络:DNS、子网掩码、网关

参考&#xff1a; https://blog.csdn.net/weixin_55255438/article/details/123074896 https://zhuanlan.zhihu.com/p/65226634 在计算机网络中&#xff0c;DNS&#xff08;Domain Name System&#xff0c;域名系统&#xff09;、子网掩码&#xff08;Subnet Mask&#xff09;…

优化RoBERTa:在AMD上使用混合精度进行微调

Optimizing RoBERTa: Fine-Tuning with Mixed Precision on AMD — ROCm Blogs 简介 在这篇博客中&#xff0c;我们将探讨如何微调鲁棒优化的BERT预训练方法&#xff08;[RoBERTa](https://arxiv.org/abs/1907.11692)&#xff09;大型语言模型&#xff0c;重点在于PyTorch的混…

遥感之大豆提取

主要记录大豆提取常用的光学以及sar等特征&#xff0c;以便在实验中实现考虑以下特征得到初步结果&#xff0c;在其基础上进行不同维度的优化。 参考文献**<Mapping annual 10-m soybean cropland with spatiotemporal sample migration>** 文档总体描述&#xff1a; …

Java类的加载器分类

启动类加载器 使用-XX:TraceClassLoading参数得到 扩展类加载器 应用程序类加载器 用户自定义类加载器 测试不同类的加载器