Vue学习105~116(Vuex)
创始人
2025-05-31 22:10:32
0

原理图:

在这里插入图片描述

4.1 概念

​ 在Vue中实现集中式状态(数据)管理的一个Vue插件,对vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。

4.2 何时使用Vuex?

  1. 多个组件依赖于同一状态
  2. 来自不同组件的行为需要变更同一状态

4.3 搭建vuex环境

vue2中,要用vuex的3版本

npm i vuex@3

vue3中,要用vuex的4版本

  1. 创建文件:src/store/index.js

    //引入Vue核心库
    import Vue from 'vue'
    //引入Vuex
    import Vuex from 'vuex'
    //应用Vuex插件
    Vue.use(Vuex)//准备actions对象——响应组件中用户的动作
    const actions = {}
    //准备mutations对象——修改state中的数据
    const mutations = {}
    //准备state对象——保存具体的数据
    const state = {}//创建并暴露store
    export default new Vuex.Store({actions,mutations,state
    })
    
  2. main.js中创建vm时传入store配置项

    ......
    //引入store
    import store from './store'
    ......//创建vm
    new Vue({el:'#app',render: h => h(App),store
    })
    

4.4 基本使用

  1. 初始化数据、配置actions、配置mutations,操作文件store.js

    //引入Vue核心库
    import Vue from 'vue'
    //引入Vuex
    import Vuex from 'vuex'
    //引用Vuex
    Vue.use(Vuex)const actions = {//响应组件中加的动作jia(context,value){// console.log('actions中的jia被调用了',miniStore,value)context.commit('JIA',value)},
    }const mutations = {//执行加JIA(state,value){// console.log('mutations中的JIA被调用了',state,value)state.sum += value}
    }//初始化数据
    const state = {sum:0
    }//创建并暴露store
    export default new Vuex.Store({actions,mutations,state,
    })
    
  2. 组件中读取vuex中的数据:$store.state.sum

  3. 组件中修改vuex中的数据:$store.dispatch('action中的方法名',数据)$store.commit('mutations中的方法名',数据)

    备注:若没有网络请求或其他业务逻辑,组件中也可以越过actions,即不写dispatch,直接编写commit

具体案例:

index.js

//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
//应用Vuex插件
Vue.use(Vuex)//准备actions——用于响应组件中的动作
const actions = {/* jia(context,value){console.log('actions中的jia被调用了')context.commit('JIA',value)},jian(context,value){console.log('actions中的jian被调用了')context.commit('JIAN',value)}, */jiaOdd(context,value){console.log('actions中的jiaOdd被调用了')if(context.state.sum % 2){context.commit('JIA',value)}},jiaWait(context,value){console.log('actions中的jiaWait被调用了')setTimeout(()=>{context.commit('JIA',value)},500)}
}
//准备mutations——用于操作数据(state)
const mutations = {JIA(state,value){console.log('mutations中的JIA被调用了')state.sum += value},JIAN(state,value){console.log('mutations中的JIAN被调用了')state.sum -= value}
}
//准备state——用于存储数据
const state = {sum:0 //当前的和
}//创建并暴露store
export default new Vuex.Store({actions,mutations,state,
})

Count.vue


4.5 getters的使用

  1. 概念:当state中的数据需要经过加工后再使用时,可以使用getters加工。

  2. store.js中追加getters配置

    ......const getters = {bigSum(state){return state.sum * 10}
    }//创建并暴露store
    export default new Vuex.Store({......getters
    })
    
  3. 组件中读取数据:$store.getters.bigSum

4.6 四个map方法的使用

导入

import {mapState, mapGetters, mapActions, mapMutations} from 'vuex'
  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生成:incrementOdd、incrementWait(对象形式)...mapActions({incrementOdd:'jiaOdd',incrementWait:'jiaWait'})//靠mapActions生成:incrementOdd、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使用时,若需要传递参数需要:在模板中绑定事件时传递好参数,否则传的参数是事件对象(event)。

具体案例:

4.7 模块化+命名空间

  1. 目的:让代码更好维护,让多种数据分类更加明确。

  2. 修改store.js

    const countAbout = {namespaced:true,//开启命名空间state:{x:1},mutations: { ... },actions: { ... },getters: {bigSum(state){return state.sum * 10}}
    }const personAbout = {namespaced:true,//开启命名空间state:{ ... },mutations: { ... },actions: { ... }
    }const store = new Vuex.Store({modules: {countAbout,personAbout}
    })
    
  3. 开启命名空间后,组件中读取state数据:

    //方式一:自己直接读取
    this.$store.state.personAbout.list
    //方式二:借助mapState读取:
    // 用 mapState 取 countAbout 中的state 必须加上 'countAbout'
    ...mapState('countAbout',['sum','school','subject']),
    
  4. 开启命名空间后,组件中读取getters数据:

    //方式一:自己直接读取
    this.$store.getters['personAbout/firstPersonName']
    //方式二:借助mapGetters读取:
    ...mapGetters('countAbout',['bigSum'])
    
  5. 开启命名空间后,组件中调用dispatch

    //方式一:自己直接dispatch
    this.$store.dispatch('personAbout/addPersonWang',person)
    //方式二:借助mapActions:
    ...mapActions('countAbout',{incrementOdd:'jiaOdd',incrementWait:'jiaWait'})
    
  6. 开启命名空间后,组件中调用commit

    //方式一:自己直接commit
    this.$store.commit('personAbout/ADD_PERSON',person)
    //方式二:借助mapMutations:
    ...mapMutations('countAbout',{increment:'JIA',decrement:'JIAN'}),
    

具体案例:
count.js

//求和相关的配置
export default {namespaced:true,actions:{jiaOdd(context,value){console.log('actions中的jiaOdd被调用了')if(context.state.sum % 2){context.commit('JIA',value)}},jiaWait(context,value){console.log('actions中的jiaWait被调用了')setTimeout(()=>{context.commit('JIA',value)},500)}},mutations:{JIA(state,value){console.log('mutations中的JIA被调用了')state.sum += value},JIAN(state,value){console.log('mutations中的JIAN被调用了')state.sum -= value},},state:{sum:0, //当前的和school:'尚硅谷',subject:'前端',},getters:{bigSum(state){return state.sum*10}},
}

person.js

//人员管理相关的配置
import axios from 'axios'
import { nanoid } from 'nanoid'
export default {namespaced:true,actions:{addPersonWang(context,value){if(value.name.indexOf('王') === 0){context.commit('ADD_PERSON',value)}else{alert('添加的人必须姓王!')}},addPersonServer(context){axios.get('https://api.uixsj.cn/hitokoto/get?type=social').then(response => {context.commit('ADD_PERSON',{id:nanoid(),name:response.data})},error => {alert(error.message)})}},mutations:{ADD_PERSON(state,value){console.log('mutations中的ADD_PERSON被调用了')state.personList.unshift(value)}},state:{personList:[{id:'001',name:'张三'}]},getters:{firstPersonName(state){return state.personList[0].name}},
}

index.js

//该文件用于创建Vuex中最为核心的store
import Vue from 'vue'
//引入Vuex
import Vuex from 'vuex'
import countOptions from './count'
import personOptions from './person'
//应用Vuex插件
Vue.use(Vuex)//创建并暴露store
export default new Vuex.Store({modules:{countAbout:countOptions,personAbout:personOptions}
})

count.vue

person.vue

相关内容

热门资讯

车企价格战没有赢家,工信部将加... 【#车企价格战没有赢家#,#工信部将加力整治车企内卷式竞争#】近期,多家汽车企业发起新一轮大范围降价...
黄金股早盘逆势走高 潼关黄金涨... .ct_hqimg {margin: 10px 0;} .hqimg_wrapper {text-a...
以全球视野讲述“京西故事” “... 6月1日,“你好,石景山”入境游推广活动精彩举办。作为2025北京入境旅游发展大会的重要组成部分,石...
全国首个“上美影”IP主题乐园... 转自:上观新闻6月1日儿童节,位于普陀区环球港2楼,全国首家以上海美术电影制片厂(以下简称“上美影”...
本月起你的工资将多一笔钱,看各... 转自:上观新闻从本月起,各地开始发放高温津贴,你的工资卡里将多收到一笔钱。《防暑降温措施管理办法》明...
美国发生袭击亲以色列团体事件,... 当地时间6月1日,美国科罗拉多州博尔德市一名男子向人群投掷燃烧瓶,造成6人烧伤。美国联邦调查局(FB...
尘埃落定! 2024/25榨季... 5月22日,云南最后一家制糖企业收榨,标志着云南省2024/2025榨季生产圆满结束,本榨季云南累计...
马斯克:不想做替罪羊 转自:长安街知事微信公众号据央视新闻报道,当地时间6月1日,美国企业家埃隆·马斯克在接受美国哥伦比亚...
突发!CZ6850航班,立即返... 据中国南方航空消息,5月31日,CZ6850杭州飞往深圳的航班上,一旅客携带的相机电池、充电宝,出现...
华鑫证券-食品饮料行业周报:白... (转自:研报虎)投资要点▌一周新闻速递  行业新闻:1)1-4月酒饮茶制造业营收增长3.7%;2)江...
太湖三宝苏超联赛整整齐齐一场未... 转自:荔枝新闻 【#太湖三宝苏超联赛整整齐齐一场未胜##...
【环球财经】1-5月俄罗斯经土... 转自:新华财经新华财经莫斯科6月2日电(记者 包诺敏)据塔斯社援引欧洲天然气输送系统运营商网络(EN...
用户画像分析,短视频平台用户画...   客户引流是营销推广的重中之重,但盲目跟风引流必然导致资源消耗和劳动力的增加。      用户画像...
国家能源集团声明:从未设立任何... 人民财讯6月2日电,国家能源集团发布声明称,近期,国家能源集团发现有不法分子假冒国家能源集团在全国多...
韩剧看见味道的少女一共多少集 韩剧看见味道的少女一共多少集一共16集 。
夏季雪乡盛妆开园,开启清凉狂欢... 转自:龙头新闻·黑龙江日报文丨龙头新闻·黑龙江日报  马一梅 李健6月1日,雪乡国家森林公园正式开园...
创业者典型画像,创业者有哪些典...   “青春不是资本,还有什么是资本?”英雄娱乐CEO应淑玲说,上帝让人们变老,只是为了让年轻人取代他...
社会主义核心价值观社会层面视频...         正在加载视频.      (建议在WIFI环境下观看视频)            整...
港股异动丨内房股集体下跌,富力... 格隆汇6月2日|内地5月百城二手房价环比跌幅扩大,港股市场内房股集体下跌。其中,富力地产跌超7%,龙...
商务部:美方倒打一耙!中方坚决... 商务部网站截图有记者问:近日,美方不断有消息称,中方违反中美日内瓦经贸会谈共识,请问商务部对此有何评...