(四十一)Vuex之模块化与命名空间

文章目录

  • 模块化
  • 命名空间
  • 模块动态注册
    • 保留 state
  • 模块重用

上一篇:(四十)vuex之四个map辅助函数

模块化

在复杂的应用中,为了解决 Vuex store 对象变得臃肿的问题,可以使用 Vuex 模块(module)来对 store 进行分割。每个模块都具有自己的 state、mutation、action 和 getter,甚至可以包含嵌套的子模块。

通过将 store 分割成模块,可以实现以下优势:

  • 逻辑分离:将相关的状态、变更、行为和计算逻辑组织在一个模块中,使代码更具可读性和可维护性。每个模块只关注自己的状态和操作,减少了模块间的耦合性。
  • 可扩展性:通过模块化的方式,可以更方便地扩展和修改应用的状态。当应用变得复杂时,可以通过添加新的模块来处理新的功能需求,而不必修改现有的模块。
  • 命名空间:每个模块都具有自己的命名空间,防止不同模块之间的命名冲突。这样可以更好地组织和管理应用的状态,避免命名冲突引发的问题。
const moduleA = {state: () => ({ ... }),mutations: { ... },actions: { ... },getters: { ... }
}const moduleB = {state: () => ({ ... }),mutations: { ... },actions: { ... }
}const store = new Vuex.Store({modules: {a: moduleA,b: moduleB}
})store.state.a // -> moduleA 的状态
store.state.b // -> moduleB 的状态

命名空间

命名空间是 Vuex 中用于解决模块化命名冲突的机制。当多个模块具有相同的 mutation、action 或 getter 名称时,使用命名空间可以确保它们在调用时不会发生冲突。

在 Vuex 模块中,默认情况下,mutation、action 和 getter 的名称是全局的,即它们在整个应用中是唯一的。但是,当应用变得复杂并且包含多个模块时,可能会出现命名冲突的情况。这时,可以通过给模块设置命名空间来区分不同模块的命名空间。

在模块中设置命名空间可以通过 namespaced 属性来实现。将 namespaced 属性设置为 true,即可启用命名空间。启用命名空间后,模块内部的 mutation、action 和 getter 将只在其所属的命名空间内生效。

const moduleA = {namespaced: true, // 启用命名空间state: { ... },mutations: { ... },actions: { ... },getters: { ... }
};export default moduleA;

在使用命名空间时,调用模块内部的 mutation、action 和 getter 需要使用命名空间前缀。可以使用 namespace 辅助函数来简化命名空间的使用。

export default {computed: {...mapState('moduleA', ['xxx']),...mapGetters('moduleB', ['xxx'])},methods: {...mapActions('moduleA', ['xxx']),...mapMutations('moduleB', ['xxx'])}
}

使用 mapState、mapGetters、mapActions 和 mapMutations 辅助函数来从 moduleA 模块和 moduleB 模块中映射状态、计算属性、操作和变更。通过在函数调用中指定模块的命名空间,可以正确地引用相应模块的内容。

使用命名空间可以在复杂的应用中避免命名冲突,提高代码的可维护性和可读性。它使得模块内部的 mutation、action 和 getter 更加封装和独立,避免了不同模块之间的相互干扰。

模块动态注册

在 Vuex 中,可以使用动态注册(Dynamic Registration)来动态添加和注册模块。这允许在应用运行时根据需要添加新的模块,而不必在初始化时将所有模块都注册到 Vuex store 中。

动态注册模块可以使用 registerModule 方法来实现。该方法接受两个参数:path 和 module。path 是一个字符串字符串数组,用于指定模块在 state 树中的位置,module 是一个包含模块的对象。

// 将dynamicModule进行动态注册
export default {methods: {registerDynamicModule() {import('./dynamicModule').then(module => {const dynamicModule = module.default;// 1.1动态注册模块this.$store.registerModule('dynamic', dynamicModule);// 1.2嵌套动态注册(对象写法)this.$store.registerModule('store.dynamic', dynamicModule);// 1.3嵌套动态注册(数组写法)this.$store.registerModule(['store','dynamic'], dynamicModule);});},unregisterDynamicModule() {// 2.1取消动态注册的模块this.$store.unregisterModule('dynamic');// 2.2取消嵌套动态注册的模块(对象写法)this.$store.unregisterModule('store.dynamic');// 2.3取消嵌套动态注册的模块(数组写法)this.$store.unregisterModule(['store','dynamic']);}}
};

通过动态注册模块,可以根据应用的需要在运行时添加或移除模块,灵活地管理应用的状态。这对于需要按需加载模块或根据用户操作动态添加功能的场景非常有用。注意,在取消注册模块时,要确保模块的状态和操作已经不再需要,以避免潜在的错误或内存泄漏。

保留 state

在注册一个新 module 时,你很有可能想保留过去的 state,例如从一个服务端渲染的应用保留 state。

可以使用 Vuex 的 preserveState 选项。当注册模块时,你可以通过传递 { preserveState: true } 选项来保留模块的状态。这样,在取消注册模块后,状态仍然会保留在根状态树中。

export default {methods: {registerModule() {import('./module').then(module => {const module = module.default;// 动态注册模块并保留状态this.$store.registerModule('moduleName', module, { preserveState: true });});},unregisterModule() {// 取消动态注册的模块this.$store.unregisterModule('moduleName');}}
};

通过使用 preserveState 选项,取消注册模块后,模块的状态将保留在根状态树中,以便在需要时可以重新注册并恢复状态。这对于需要在模块之间动态切换或临时取消注册模块的情况非常有用。

模块重用

在 Vuex 中,可以通过模块重用的方式来减少重复的代码和逻辑。模块重用允许你在多个地方注册相同的模块,以便在不同的上下文中共享模块的状态和功能。

要实现模块重用,你可以在 Vuex 的模块定义中使用工厂函数,该函数返回模块对象,以便可以在不同的地方多次调用。

// 模块工厂函数
function createModule() {return {state: { ... },mutations: { ... },actions: { ... },getters: { ... }};
}const store = new Vuex.Store({state: { ... },mutations: { ... },actions: { ... },getters: { ... },modules: {moduleA: createModule(), // 注册模块AmoduleB: createModule() // 注册模块B}
});export default store;

这么说可能比较抽象,举一个例子说明,我们可以使用模块重用来共享用户信息的状态和相关操作。

首先,我们定义一个模块工厂函数,用于创建用户信息模块。在该模块中,我们可以定义状态、变异、动作和获取器等内容。

// userModule.js
export default function createUserModule() {return {namespaced: true,state: {user: null},mutations: {SET_USER(state, user) {state.user = user;}},actions: {setUser({ commit }, user) {commit('SET_USER', user);}},getters: {getUser(state) {return state.user;}}};
}

模块重用在以下场景中非常有用:

  • 多个页面共享相同的状态和逻辑:如果你有多个页面需要访问和修改相同的状态,并且具有相似的逻辑和功能,可以使用模块重用来共享这些状态和功能。这样,你可以在每个页面中注册相同的模块,并在不同的上下文中使用相同的状态和操作。
  • 不同的组件需要访问相同的状态:如果你有多个组件需要访问相同的状态,例如共享的用户信息或全局配置,可以使用模块重用来注册这些共享状态的模块。这样,不同的组件可以通过在模块中定义的获取器来访问相同的状态,避免了需要在每个组件中重复定义和同步状态的问题。
const store = new Vuex.Store({modules: {user: createUserModule() // 注册用户信息模块,这个用户信息模块就可以全局使用}
});export default store;
  • 模块实例具有独立性:如果你需要在应用程序中创建多个独立的用户信息模块实例,每个实例具有自己的状态和操作,需要多次调用createUserModule 来创建不同的模块实例。这样每个模块实例将独立管理自己的状态,并且彼此之间不会相互影响。
const store = new Vuex.Store({modules: {user1: createUserModule(), // 创建第一个用户信息模块实例user2: createUserModule() // 创建第二个用户信息模块实例}
});export default store;
  • 动态注册和取消注册模块:模块重用还可以在需要动态注册和取消注册模块的情况下发挥作用。如果你需要在运行时根据条件注册或取消注册模块,可以使用模块重用来定义模块工厂函数,并在需要时多次调用该函数来注册或取消注册模块。
const store = new Vuex.Store({modules: {}
});// 动态注册用户信息模块
function registerUserModule(moduleName) {store.registerModule(moduleName, createUserModule());
}// 动态取消注册用户信息模块
function unregisterUserModule(moduleName) {store.unregisterModule(moduleName);
}export default store;

通过这种方式,我们可以在不同的页面中共享用户信息模块,避免了重复定义和同步用户信息的问题,我们可能需要多次调用 模块工厂函数 来创建多个模块实例,通过模块重用,能够提高代码的可维护性和重用性,减少重复的代码和逻辑。

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

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

相关文章

DY-34/60C电压继电器 带板前底座 约瑟JOSEF

系列型号: DY-32电压继电器;DY-36电压继电器; DY-33电压继电器;DY-37电压继电器; DY-34电压继电器;DY-38电压继电器; DY-31电压继电器;DY-35电压继电器; DY-32/60C电…

时区设置函数【man 3 tzset】

1. NAME&#xff08;名&#xff09; tzset, tzname, timezone, daylight - 初始化时间转换信息 2. SYNOPSIS&#xff08;概要&#xff09; #include <time.h>void tzset(void);extern char *tzname[2]; extern long timezone; extern int daylight;glibc的功能测试宏要…

关于从大平台跳转各个应用,更新应用前端包后,显示的仍是旧的内容,刷新应用页面后方才显示新的内容的问题的排查和解决

我们从绿洲物联平台跳转智能锁应用&#xff0c; 如下&#xff0c;我们可以看到&#xff0c;我们是通过a标签去跳转应用的。但是我们打开控制台的话&#xff0c;因为a标签是另外新开一个页面&#xff0c;我们看不到新页面的html文档的加载情况。 我们可以临时把_blank改成_sel…

动力学笔记01——共振频率和共振带的数学定义

文章目录 0、背景描述1、正文2. 位移、速度、加速度的共振频率并不相同 0、背景描述 过去一年&#xff0c;我基本都在考虑塔架&#xff08;尤其是混塔&#xff09;频率仿真/模态分析的问题。关于这个问题&#xff0c;不仅有地基刚度&#xff0c;还有塔筒本身以及其他影响频率的…

【机器学习300问】120、该怎么用RNN来构建语言模型?

一、基本概念补充 在构建语言模型之前补充几个自然语言处理&#xff08;NLP&#xff09;基本概念。 &#xff08;1&#xff09;语料库&#xff08;Corpus&#xff09; ① 语料库的定义 在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;语料库是一个经过组织和加工…

2024长三角高校数学建模:“抢救”落水手机

背景 上有天堂&#xff0c;下在苏杭&#xff1b;五一假期&#xff0c;杭州西湖、西溪湿地、京杭大运河等著名景点&#xff0c;游人如织&#xff0c;作为享誉国内外的旅游胜地&#xff0c;杭州再次成为顶流。今年五一假期&#xff0c;西湖不断忙上热搜&#xff0c;据悉今年“五…

Android adb-wm命令详解

1.wm窗口管理命令可以获取屏幕的 分辨率、像素密度 等信息&#xff0c;甚至可以临时修改屏幕的 分辨率、像素密度 等参数&#xff0c;可以很方便地查看 APP 在不同像分辨率和素密度手机/平板上的显示效果。 查看帮助 wm # 或 wm help 查看 屏幕分辨率 和 像素密度 wm size …

使用python库moviepy完成视频剪辑

1.关于moviepy和原理 moviepy事github上面的一个开源项目&#xff0c;地址是&#xff1a;GitHub - Zulko/moviepy: Video editing with Python 官方文档地址&#xff1a; User Guide — MoviePy 1.0.2 documentation 中文版文档可参考&#xff1a; MoviePy中文手册 — mov…

GitHub项目里的api

在一个GitHub项目中提到的"api"通常指的是该项目提供的应用程序编程接口&#xff08;Application Programming Interface&#xff09;。这意味着该项目包含了一套规则和工具&#xff0c;允许其他开发者通过代码调用该接口来与项目功能互动、获取数据或执行特定任务。…

Ollama:本地部署大模型 + LobeChat:聊天界面 = 自己的ChatGPT

本地部署大模型 在本地部署大模型有多种方式&#xff0c;其中Ollama方式是最简单的&#xff0c;但是其也有一定的局限性&#xff0c;比如大模型没有其支持的GGUF二进制格式&#xff0c;就无法使用Ollama方式部署。 GGUF旨在实现快速加载和保存大语言模型&#xff0c;并易于阅读…

vue中的代码分割

随着Web应用的日益复杂化&#xff0c;用户对页面加载速度的期望越来越高。在这种背景下&#xff0c;前端性能优化成为了开发者们必须面对的挑战。Vue.js&#xff0c;作为现代前端开发的首选框架之一&#xff0c;其轻量级和灵活性为构建高性能的Web应用提供了可能。然而&#xf…

软件开发背景介绍?程序员为您揭秘软件开发的流程?

本文将由小编为您介绍关于软件开发的背景及其流程&#xff0c;希望能够帮助大家更好地理解软件开发的基本概念和具体步骤。在现代信息技术飞速发展的今天&#xff0c;软件已成为推动社会进步和商业发展的重要力量。无论是个人生活还是企业运营&#xff0c;都离不开各类软件的支…

在大模型应用中,如何提升RAG(检索增强生成)的能力?

01、什么是RAG&#xff1f; RAG简单来说就是给予LLM的一些增强。 • 引入新的信息&#xff0c;这些信息可能不在LLM中。 • 使用RAG控制内容来减少幻觉&#xff08;模型生成与现实不符的输出&#xff09;&#xff0c;这是RAG的一个常见用途。通常的用例是提供内容给模型&…

java-内部类 2

### 8. 内部类的访问规则和限制 #### 8.1 访问外部类的成员 内部类可以直接访问外部类的成员变量和方法&#xff0c;包括私有成员。例如&#xff1a; java class OuterClass { private String outerField "Outer field"; class InnerClass { void di…

Vue47-修改默认配置webpack.config.js文件

main.js是脚手架项目的入口文件&#xff0c;系统运行时&#xff0c;默认去找src下的main.js文件。这是webpack通过配置文件&#xff1a;webpack.config.js配置的。 脚手架把所有重要的配置文件都隐藏了&#xff0c;方式被开发者修改。 一、查看被隐藏的webpack配置 1-1、webpa…

网线不通?瞅瞅这里----关于交叉网线的原理。

最近搞了个项目&#xff0c;UDP对接UDP&#xff0c;死活对接不上。 最后发现是交叉网线的事情&#xff0c;在此记录交叉网线的原理。 先说结论&#xff1a;不同设备用直连&#xff0c;相同设备用交叉网线 细说说 1.原理 网线的原理实际就是TX与RX对接。 正常一个设备同时有…

哪些不得不记下的汇编指令

指令 1、8种寻址方式 寄存器寻址 立即寻址 寄存器移位寻址 寄存器间接寻址 基址寻址 多寄存器寻址 堆栈寻址 相对寻址 2、6类指令&#xff1a; 数据处理指令&#xff1a; 数据传输指令&#xff0c; MOV --------传送字或字节。 …

uthash使用指南

uthash用户使用指南 uthash支持哪些操作如何使用uthash定义可以使用作hash表的结构体关于内存 声明哈希表添加元素查找元素删除元素遍历元素计数排序 我们利用哈希表可以通过键值对的方式处理元素&#xff0c;即哈希表中存储键-值形式的数据&#xff0c;关键字是唯一的。uthash…

vue3 使用 watch 时陷入了个直觉陷阱

场景&#xff1a;在vue中&#xff0c;使用watch 的场景是很常见的。编写业务代码时&#xff0c;需要监听一个或多个值的变化时&#xff0c;经常性会使用watch&#xff0c;日常使用就不提了&#xff0c;直入主题&#xff0c;来一段使用watch的简单代码&#xff0c;有一定前端水平…

秘密背后的秘密-高速PCB的层叠确认时,工厂为何不写铜箔类型

一博高速先生成员&#xff1a;王辉东 “三面青山一面湖&#xff0c;无尽烟波画舫浮。”说的是巢湖&#xff0c;到了合肥怎能不去巢湖看看呢。 周末休息&#xff0c;大刚说我开车&#xff0c;小胡&#xff08;丽华&#xff09;说我也去。 大刚说走就走&#xff0c;秒开车&…