Vue学习笔记-模块化+命名空间

目的

让代码更好维护,让多种数据分类更加明确(不同的模块挤在一个index.js中显得臃肿且不方便管理)

实现方式

  1. 修改store/index.js(也可以将不同模块分别写在不同的js文件中)

    javascript 复制代码
    const countAbout = {
    	//开启命名空间
        namespaced:true,
        actions:{
        	......
        },
        mutations:{
            ......
        },
        state:{
            sum:0,
        },
        getters:{
            bigSum(state){
                return state.sum*10
            }
        }
    }
    
    const personAbout = {
    	namespace = true,//开启命名空间
    	state = {
    		list:[xxx]
    	},
    	mutations = {...},
    	actions = {...}
    }
    
    const store = new Vuex.Store({
    	modules:{
    		countAbout,
    		personAbout
    	}
    })
  2. 开启命名空间后,组件读取各个模块的state数据

    javascript 复制代码
    //方式一:直接读取
    this.$store.state.countAbout.sum
    //方式二:借助mapState读取
    ...mapState('countAbout',['sum',...])
  3. 组件读取各个模块的getters数据

    javascript 复制代码
    //方式一:直接读取
    this.$store.getters['personAbout/firstPersonName']
    //方式二:借助mapGetters读取
    ...mapGetters('personAbout',['firstPersonName'])
  4. 组件调用dispatch

    javascript 复制代码
    //方式一:直接调用
    this.$store.dispatch('personAbout/addPerson',value)
    //方式二:借助mapActions
    ...mapActions('personAbout',{addPerson:'addPerson'})
  5. 组件调用commit

    javascript 复制代码
    //方法一:直接调用
    this.$store.commit('personAbout/ADD_PERSON',value)
    //方式二:借助mapMutations
    ...mapMutations('personAbout',{ADD_PERSON:'ADD_PERSON'})

注意:mapActions和mapMutation中无法填写函数参数,需要在html组件的@click方法声明中自己填写

相关推荐
笺上山河梦4 分钟前
文件操作(二进制文件)
开发语言·c++·学习·算法
zyq~41 分钟前
【论文阅读笔记】模型的相似性
论文阅读·笔记
chxin140161 小时前
PyTorch - Tensor 学习笔记
pytorch·笔记
虾球xz2 小时前
游戏引擎学习第221天:(实现多层次过场动画)
c++·学习·游戏引擎
christine-rr2 小时前
【25软考网工笔记】第二章 数据通信基础(2) 信道延迟计算
网络·笔记·网络工程师·软考
Willliam_william3 小时前
QEMU学习之路(8)— ARM32通过u-boot 启动Linux
linux·学习·elasticsearch
踢足球的程序员·3 小时前
OpenGL学习笔记(几何着色器、实例化、抗锯齿)
笔记·学习·图形渲染
梦幻精灵_cq4 小时前
子函数嵌套的意义——以“颜色排序”为例(Python)
学习
天下琴川4 小时前
Dify智能体平台源码二次开发笔记(6) - 优化知识库pdf文档的识别
人工智能·笔记·pdf
bingbingyihao4 小时前
个人博客系统
前端·javascript·vue.js