vuex五大核心、辅助函数

news2025/1/9 10:36:30

一、vuex五大核心

分别为:state、getters、mutations、actions、modules

  1. state:用来存放我们的状态,也可以理解数据,类似与data中定义的数据;
  2. mutations:可以获取state里面的状态,进行修改,他只能对state进行同步操作;
  3. actions:也可以获取state里面的状态,进行修改,它可以执行异步操作(用于请求数据);
  4. getters:我们可以获取到state的状态,对其进行计算并返回值,有点类似于vue里面的计算属性(computed);
  5. modules:用于模块化开发,当我们得的项目特别大的时候,保存的状态也会增加,如果都写到index.js里面,文件内容就会变得特别臃肿,导致后期难以维护,所以我们可以使用modules进行模块化处理,将多个状态抽离到对应的js文件中,最后在modules中进行合并,方便我们后期的维护。

二、调用vuex里面的属性和方法:

  1. state:可以通过this.$store.state调用;
template:
<div>{{ $store.state.userInfo }}</div>

methods使用方式:
this.$store.state.userInfo
  1. getters:可以通过this.$store.getters调用;
页面使用store中getters的属性: (getters类似于vue页面中的computed计算属性,页面中使用也是通过计算属性接收)
computed: {
  age () {
    return this.$store.getters.age
  }
}

template:
<div>{{ age }}</div>

methods使用方式:
this.age
  1. mutations(同步):可以通过this.$store.cmomit('事件名',传递的数据)触发;
template:
<button @click="handleEditAgeClick">调用mutations方法</button>

methods使用方式:
handleEditAgeClick () {
  this.$store.commit('handleSetAge', 18)
}

store/index.js
mutations: {
  handleSetAge (state, age) {
    state.userInfo.age = age
  }
}                                                 
  1. actions(异步需要加async):可以通过this.$store.dispacth('事件名',传递的数据)触发;

除了以上的方法外:我们还可以通过辅助函数的方式调用和触发(mapState、mapMutation、mapGetter、mapAction)

template:
<button @click="handleEditUserNameClick">更改用户姓名</button>

methods使用方式:
handleEditUserNameClick () {
  this.$store.dispatch('handleSetUserName', '未来的王老板')
}

store/index.js
mutations: {
  handleSetUserName (state, userName) {
    state.userInfo.userName = userName
  }
} 

三、项目实践:

在项目中如果想要改变state的状态,我们一般就是在组件里面调用thi.$store.dispach方式来触发actions里面的方法,在actions里面的方法通过commit来调用mutaions里面定义的方法来改变state,同时这也是vuex的执行机制。

四、vuex的弊端:

当我们浏览器的页面刷新的时候,vuex里面的数据会丢失,所以一般结合本地存储的方式来解决这个问题,当我们在mutations里面修改数据的时候,再通过localStorage或者sessionStorage存储到本地,然后我们在state的属性那块,写上一个三元表达式,如果本地存在数据的话,则获取数据,否则为null.

五、真正的开发实践

练习vuex目录结构:

在真正开发的时候,大多数程序猿并不会使用这样的目录结构,因为需要管理的数据很多,一个模块的话会导致后期的难以维护,所以这种目录结构只适合新手练习使用。

实战vuex目录结构:

import Cookies from 'js-cookie'

const state = {
  sidebar: {
    opened: Cookies.get('sidebarStatus') ? !!+Cookies.get('sidebarStatus') : true,
    withoutAnimation: false
  },
  device: 'desktop'
}

const mutations = {
  TOGGLE_SIDEBAR: state => {
    state.sidebar.opened = !state.sidebar.opened
    state.sidebar.withoutAnimation = false
    if (state.sidebar.opened) {
      Cookies.set('sidebarStatus', 1)
    } else {
      Cookies.set('sidebarStatus', 0)
    }
  },
  CLOSE_SIDEBAR: (state, withoutAnimation) => {
    Cookies.set('sidebarStatus', 0)
    state.sidebar.opened = false
    state.sidebar.withoutAnimation = withoutAnimation
  },
  TOGGLE_DEVICE: (state, device) => {
    state.device = device
  }
}

const actions = {
  toggleSideBar({ commit }) {
    commit('TOGGLE_SIDEBAR')
  },
  closeSideBar({ commit }, { withoutAnimation }) {
    commit('CLOSE_SIDEBAR', withoutAnimation)
  },
  toggleDevice({ commit }, device) {
    commit('TOGGLE_DEVICE', device)
  }
}

export default {
  namespaced: true, // 命名空间: 模块开启命名空间后,享有独自的命名空间
  state,
  mutations,
  actions
}



// namespaced: true 
// 原因: 在多人协作开发的时候,可能子模块和主模块中的函数名字会相同,
// 这样在调用函数的时候,相同名字的函数都会被调用,就会发生问题。
// 为了解决这个问题,导出模块的时候要加namespace:true.

使用方式:将modules下的app.js模块导入index.js中:

import Vue from "vue";
import Vuex from "vuex";
import getters from "./getters";
import app from "./modules/app";

// modules引入---注册
Vue.use(Vuex);

const store = new Vuex.Store({
  modules: {
    app
  },
  getters, // getters 模块 与 index.js模块同级
});

export default store;

getters使用方式:暴露给页面需要用到的数据

const getters = {
  sidebar: (state) => state.app.sidebar
};
export default getters;

六、辅助函数

简介:一般情况下,如果需要访问vuex.store中state存放的数据,需要使用this.$store.state.属性名方式。显然,采取这样的数据访问方式,代码略显繁杂,辅助函数为了解决繁杂行问题应运而生。

介绍:通过辅助函数mapGetters、mapState、mapActions、mapMutations,把vuex.store中的属性映射到vue实例身上,这样在vue实例中就能访问vuex.store中的属性了,对于操作vuex.store就变得非常方便。

state辅助函数为mapState,

actions辅助函数为mapActions,

mutations辅助函数为mapMutations。(

Vuex实例身上有mapState、mapActions、mapMutations属性,属性值都是函数)

七、辅助函数的使用

如何使用辅助函数:

  1. 需要在当前组件中引入Vuex。 import { 辅助函数 } from 'Vuex'
  2. 通过Vuex来调用辅助函数。computed: { ...mapState }
// mapState: 把 state 属性映射到 computed 身上

// 普通形式:
import { mapGetters } from 'vuex'
computed:{
   ...Vuex.mapState({
      input:state=>state.inputVal,
      n:state=>state.n
  })   
}

// 简写形式
import { mapGetters } from 'vuex'
computed:{
	...mapGetters(['input', 'n'])
}

/**
 * state:用来存储公共状态, state中存储的数据都是响应式的。
 * 响应式原因:state里面有getters、setters方法;
 * data中的数据也是响应式的,因为里面也有getters和setters方法。
 * 在computed属性中来接收state中的数据,接收方式有2种(数组和对象,推荐对象)
 */

// 普通形式:
import { mapActions } from 'vuex'
methods:{
    ...Vuex.mapActions({
        add:"handleTodoAdd",    // val为actions里面的方法名称
        change:"handleInput"     
    })
}

// 简写形式:
import { mapActions } from 'vuex'
methods:{  
	...mapActions(['add', 'change'])
}

/**
 * add、change为action方法别名,直接代用add和change方法就行,
 * 不过要记得在actions里面做完数据业务逻辑的操作。
 * 等价于如下的函数调用(使用方式与vuex五大核心一样):
 */
methods: {
	handleInput(e){           
		let val = e.target.value;
		this.$store.dispatch("handleInput",val )
	},
	handleAdd(){
		this.$store.dispatch("handleTodoAdd")
	}
}
/**
 * actions里面的函数主要用来处理异步操作以及一些业务逻辑,
 * 每一个函数里面都有一个形参,这个形参是一个对象,
 * 里面有一个commit方法,这个方法用来触发mutations里面的方法。
 */
/**
 * 只是做简单的数据修改(例如n++),它没有涉及到数据处理,没有用到业务逻辑或者异步函数,
 * 可以直接调用mutations里的方法修改数据。
 */

// 普通形式:
import { mapMutations} from 'vuex'
methods:{
    ...Vuex.mapMutations({
        handleAdd:"handlMutationseAdd"
    })
}

// 简写形式:
import { mapMutations} from 'vuex'
methods:{  
	...mapMutations(['handleAdd'])
}

/**
 * mutations里面的函数主要用来修改state中的数据。
 * mutations里面的所有方法都会有2个参数,一个是store中的state,另外一个是需要传递的参数。
 * 理解state、actions、mutations,可以参考MVC框架。
 */

/**
 * state看成一个数据库,只是它是响应式的,刷新页面数据就会改变;
 * actions看成controller层,做数据的业务逻辑;
 * mutations看成model层,做数据的增删改查操作。
 */
// 普通形式:
import { mapGetters} from 'vuex'
computed:{
    ...Vuex.mapGetters({
        NumN:"NumN"
    })
}

// 简写形式:
import { mapGetters} from 'vuex'
methods:{  
	...mapGetters(['NumN'])
}

/**
 * getters类似于组件里面computed,同时也监听属性的变化,
 * 当state中的属性发生改变的时候就会触发getters里面的方法。
 * getters里面的每一个方法中都会有一个参数 state。
 */
// 把公共的状态按照模块进行划分。
/**
 * 1、每个模块都相当于一个小型的Vuex ;
 * 2、每个模块里面都会有state getters actions mutations ;
 * 3、切记在导出模块的时候加一个 namespaced:true 主要的作用是将每个模块都有独立命名空间;
 * 4、namespace:true在多人协作开发的时候,可能子模块和主模块中的函数名字会相同,
  这样在调用函数的时候,相同名字的函数都会被调用,就会发生问题。
  为了解决这个问题,导出模块的时候要加namespace:true.
 */

那么怎么调用子模块中的函数呢?

假如我的子模块名字为todo.js。 函数名字就需要改成todo/函数名字。

可以看到模块化后,store实例的state属性访问方式也改变了,this.$store.state.todo.inputVal

八、扩展

  1. vue中vuex中的state与页面中的data有什么区别?

Vue中的data是组件内部的数据,而Vuex中的state是全局公用的数据。在Vue中,当一个组件需要和其他组件共享数据时,需要通过父子组件传递props或者事件的方式进行传递,而在Vuex中,所有组件都可以访问全局的state数据,从而实现了组件之间的数据共享。此外,Vuex中的state是响应式的,当state数据发生变化时,所有依赖该数据的组件都会自动更新。而在Vue中,data数据的变化只会影响到该组件本身。

  1. vue中vuex中的getters与页面中的computed有什么区别吗?

Vue中的computed是组件内部的计算属性,而Vuex中的getters是全局公用的计算属性。在Vue中,computed属性是依赖于data属性的计算属性,当data属性发生变化时,computed属性会自动更新。而在Vuex中,getters是依赖于state属性的计算属性,当state属性发生变化时,getters会自动更新。另外,Vuex中的getters可以接收state作为参数,从而实现对state数据的复杂计算和处理。而在Vue中,computed只能依赖于组件内部的data属性和props属性进行计算。因此,getters和computed虽然在实现上有些相似,但它们的作用和使用场景是不同的。

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

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

相关文章

Hadoop---10、生产调优手册

1、HDFS—核心参数 1.1 NameNode 内存生产配置 1、NameNode内存计算 每个文件块大概占用150byte&#xff0c;一台服务器128G内存为例&#xff0c;能储存多少文件块呢&#xff1f; 12810241024*1024/150Byte ≈ 9.1 亿 G M KB Byte 2、Hadoop2.x系列&#xff0c;配置 NameNode…

leetcode506.相对名次

题目描述跳转leetcode详情 给你一个长度为 n 的整数数组 score &#xff0c;其中 score[i] 是第 i 位运动员在比赛中的得分。所有得分都 互不相同 。 运动员将根据得分 决定名次 &#xff0c;其中名次第 1 的运动员得分最高&#xff0c;名次第 2 的运动员得分第 2 高&#xff0…

day1 -- 资料库管理系统DBMS

学习目标&#xff1a; 了解什么是Mysql 如何安装Mysql 学习内容&#xff1a; 资料库概念资料库管理系统概念资料库管理系统分类SQL是什么安装Mysql启动Mysql并建立一张测试表格 正文部分 资料库 比如你喜欢摘抄优美的词句&#xff0c;那些优美的词句就是一种文字资料&#xf…

香橙派4和树莓派4B构建K8S集群实践之六:App服务部署

目录 1. 说明 1.1 关于PHPNginx体系的WebApp&#xff0c;这里将实践两种部署模式&#xff1a; 1.2 配置清单 2. PHPNginx体系的WebApp部署 2.1 单节点多容器模式A 2.1.1 准备工作 2.2.2 部署 2.2.3 访问效果 ​编辑 2.2 多节点单容器模式B 2.2.1 准备工作 2.2 配置…

笔记 | FastAPI创建新项目

当使用FastAPI创建项目时&#xff0c;首先需要安装FastAPI和其依赖项。可以使用pip来安装它们。请确保已经安装了Python和pip。 创建项目文件夹并进入该文件夹&#xff1a; mkdir myproject cd myproject创建并激活一个新的Python虚拟环境&#xff08;可选&#xff0c;但强烈…

虚拟机扩容

文章目录 虚拟机扩容扩容背景软件版本操作步骤1、VM上修改磁盘信息2、在系统中挂载磁盘(1) 使用命令查看磁盘状态(2) 通过命令查看到新磁盘的分区(3) 然后对新加的磁盘进行分区操作(4)重启虚拟机(5) 再次用以下命令查看到磁盘当前情况(6) 查看卷组名(7) 初始化刚刚的分区(8) 将…

MongoDB入门

mongodb与sql术语对应关系 SQL术语/概念MongoDB术语/概念解释/说明databasedatabase数据库tablecollection数据库表/集合rowdocument数据记录行/文档columnfield数据字段/域indexindex索引 对应关系图例

Microsoft Edge有哪些你不知道却超级好用的插件?(Microsoft Edge功能测评)

&#x1f388;个人主页:&#x1f388; :✨✨✨初阶牛✨✨✨ &#x1f43b;推荐专栏: &#x1f354;&#x1f35f;&#x1f32f;C语言进阶 &#x1f511;个人信条: &#x1f335;知行合一 &#x1f349;本篇简介:>:对Edge浏览器的简单测评,分享一些自己在使用好用的插件. 目录…

阿里系文生图(PAI+通义)

PAI-Diffusion模型来了&#xff01;阿里云机器学习团队带您徜徉中文艺术海洋 - 知乎作者&#xff1a;汪诚愚、段忠杰、朱祥茹、黄俊导读近年来&#xff0c;随着海量多模态数据在互联网的爆炸性增长和训练深度学习大模型的算力大幅提升&#xff0c;AI生成内容&#xff08;AI Gen…

Ae 效果详解:3D 摄像机跟踪器

Ae菜单&#xff1a;效果/透视/3D 摄像机跟踪器 Effects/Perspective/3D Camera Tracker 使用 3D 摄像机跟踪器 3D Camera Tracker效果可自动分析视频&#xff0c;以便提取摄像机运动和 3D 场景数据。然后&#xff0c;可以在 2D 素材的基础上正确合成 3D 元素。 提示&#xff1a…

基于DataX的海量时序数据迁移实战:从MySQL到TDengine3.x

背景 MySQL 数据库中&#xff0c;设备历史数据单表过亿&#xff0c;如何快速、低成本地迁移到 TDengine3.x 中&#xff1f; 从标题可以看出&#xff0c;我们使用的数据迁移/同步工具是 DataX &#xff0c;数据源&#xff08; Source &#xff09;为传统的关系型数据库 MySQL …

Yarn学习笔记

Apache Hadoop YARN &#xff08;Yet AnotherResource Negotiator&#xff0c;另一种资源协调者&#xff09;是一种新的 Hadoop 资源管理器&#xff0c;它是一个通用资源管理系统&#xff0c;可为上层应用提供统一的资源管理和调度&#xff0c;它的引入为集群在利用率、资源统一…

全面SOA化的电子电气架构是什么样?

交流群 | 进“传感器群/滑板底盘群/汽车基础软件群/域控制器群”请扫描文末二维码&#xff0c;添加九章小助手&#xff0c;务必备注交流群名称 真实姓名 公司 职位&#xff08;不备注无法通过好友验证&#xff09; 作者 | 张萌宇 在汽车产业向智能化转型的过程中&#xff0c…

《C++程序设计原理与实践》笔记 第18章 向量和数组

本章将介绍如何拷贝以及通过下标访问向量。为此&#xff0c;我们讨论一般的拷贝技术&#xff0c;并考虑向量与底层数组表示之间的关系。我们将展示数组与指针的关系及其使用引发的问题。我们还将讨论对于每种类型必须考虑的五种基本操作&#xff1a;构造、默认构造、拷贝构造、…

C++中queue的用法(超详细,入门必看)

博主简介&#xff1a;Hello大家好呀&#xff0c;我是陈童学&#xff0c;一个与你一样正在慢慢前行的人。 博主主页&#xff1a;陈童学哦 所属专栏&#xff1a;CSTL 前言&#xff1a;Hello各位小伙伴们好&#xff01;欢迎来到本专栏CSTL的学习&#xff0c;本专栏旨在帮助大家了解…

轩辕:首个千亿级中文金融对话模型

背景 目前开源的大语言模型或多或少存在以下痛点&#xff1a; 缺少专门针对中文进行优化过的的大语言模型。 支持中文的开源模型的参数规模偏小&#xff0c;没有超过千亿。比如清华和智谱AI的ChatGLM-6B目前只开源了6B参数模型&#xff0c;盘古alpha也只开源了13B的模型。 支…

杨立昆:科学之路读书笔记1

杨立昆&#xff1a;科学之路读书笔记1 前言科学之路1读书缘由靠省钱&#xff0c;是混不出名堂的AI趣事话题交流 一起学AI系列博客&#xff1a;目录索引 前言 在贝尔实验室&#xff0c;靠节省开支&#xff0c;是无法混出名堂的。——《科学之路》 五一假期读的多&#xff0c;写的…

毫米波雷达点云 DBSCAN聚类算法

毫米雷达点云 DBSCAN聚类算法 聚类的目的聚类算法分类原型聚类层次聚类密度聚类 DBSCAN聚类算法原理相关定义算法流程以及伪代码DBSCAN算法优缺点DBSCAN参数选择聚类衡量指标 DBSCAN算法仿真DBSCAN代码DBSCAN算法对毫米波雷达点云数据进行聚类 聚类的目的 聚类的目的是将一组数…

认识http协议---3

hi,大家好,今天为大家带来http协议的相关知识 &#x1f347;1.http状态响应码 &#x1f347;2.构造http请求 1.直接在地址栏里输入一个URL 2.html的一些特殊标签,触发get请求 3.提交form表单,可以触发get请求和post请求 4.使用ajax &#x1f347;3.再次谈同步和异步 &#x1f3…

spark sql(四)物理计划解析

1、流程解析 在该系列第二篇文章中介绍了spark sql整体的解析流程&#xff0c;我们知道整体的sql解析分为未解析的逻辑计划&#xff08;Unresolved LogicalPlan&#xff09;、解析后的逻辑计划&#xff08;LogicalPlan&#xff09;、优化后的逻辑计划&#xff08;Optimized Lo…