vue2学习 -- vuex

文章目录

    • [1. 理解](#1. 理解)
    • [2. 语法](#2. 语法)
      • [2.1 安装使用](#2.1 安装使用)
      • [2.2 getters配置项](#2.2 getters配置项)
      • [2.3 四个map方法的使用](#2.3 四个map方法的使用)
      • [2.4 vuex模块化](#2.4 vuex模块化)

1. 理解

  1. 概念:专门在ue中实现集中式状态(数据)管理的一个ue插件,对vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适
    用于任意组件间通信。
  2. Github地址https://github.com/vuejs/vuex
    ❓什么时候使用Vuex
    • 多个组件依赖于同一状态
    • 来自不同组件的行为需要变更同一状态

2. 语法

2.1 安装使用

搭建vuex环境

  1. 安装插件

npm i vuex@3(默认为4版本,只能用于vue3,3版本为vue2版本)

  1. use插件

Vue.use(vuex)


如果出现以下报错,检查一下是不是写成了new Vue.Store({...}),应该是new Vuex.Store({...})

  • 组件中读取vuex中的据:store.state.sum
  • 组件中修改Vuex中的数据:Store.dispatch('actiont中的方法名',数据)Store.commit('mutations中的方法名',数据)
    备注:若没有网络请求或其他业务逻辑,组件中也可以越过actions,即不写dispatch,直接编写commit

2.2 getters配置项

store中的getters与组件中的computed类似,可以进行复杂的数据运算。

写法与computed也一样。

2.3 四个map方法的使用

  1. mapState方法 :用于帮助我们映射state中的数据为计算属性

    computed:{
    // 借助mapState生成计算属性:sum、school、subject(对象写法)
    ...mapState({sum:'sum',school:'school',subject:'subject'}),
    //借助mapState生成计算属性:sum、school、subject(数组写法)
    ...mapState(['sum','school','subject']),
    },

  2. mapGetters方法 :用于帮助我们映射getters中的数据为计算属性

    computed:{
    // 借助mapGetters生成计算属性:bigSum(对象写法)
    ...mapGetters({bigSum:'bigSum'}),
    // 借助mapGetters生成计算属性:bigSum(数组写法)
    ...mapGetters(['bigSum'])
    },

  3. mapActions方法 :用于帮助我们生成与actions对话的方法,即:包含$store.dispatch(xxx)的函数

    methods:{
    // 靠mapActions:生成:increment0dd、incrementWait(对象形式)
    ...mapActions({incrementodd:'jiaOdd',incrementWait:'jiaWait'})
    // 靠mapActions生成:increment(0dd、incrementWait(数组形式)
    ...mapActions(['jiaOdd','jiaWait']
    }

  4. mapMutations方法 :用于帮助我们生成与mutations对话的方法,即:包含$store.commit(xxx)的函数

    methods:{
    // 靠mapActions生成:increment、decrement(对象形式)
    ...mapMutations({increment:'JIA',decrement:'JIAN')),
    // 靠mapMutations.生成:JIA、JIAN(对象形式)
    ...mapMutations(['JIA','JIAN']),
    }

备注:mapActions与mapMutations使用时,若需要传递参数需要:在模板中绑定事件时传递好参数,否则参数是事件对象

2.4 vuex模块化

转载笔记📒:vuex模块化

相关推荐
半导体守望者几秒前
AE电源闭环控制——反应溅射的集成解决方案
经验分享·学习·机器人·自动化·制造
小饕21 分钟前
RAG学习之【向量数据库】Milvus 从入门到精通:索引、检索、混合搜索一篇打通(RAG 必备)
数据库·人工智能·学习·milvus
xianrenli381 小时前
MSAI:第四周练习:思维链 (Chain-of-Thought) 提示与参数调优
学习·msai
2601_961875241 小时前
法考备考计划表|学习计划|资料已整理
java·开发语言·学习·eclipse·tomcat·c#·hibernate
qq_571099352 小时前
学习周报四十九
学习
一锅炖出任易仙2 小时前
创梦汤锅学习日记day34
学习·游戏引擎
半导体守望者2 小时前
AE AZX射频调谐器射频负载匹配(调谐)原理PPT
学习·机器人·自动化·制造·模块测试
me8322 小时前
【AI面试】大模型面试60问(面试速记+详解)
人工智能·学习·ai
CHHH_HHH2 小时前
【C++】哈希表原理与实战:从冲突解决到性能优化
开发语言·数据结构·c++·学习·算法·哈希算法·散列表
秋雨梧桐叶落莳2 小时前
iOS——QQ音乐仿写项目总结
学习·macos·ui·ios·mvc·objective-c·xcode