模块化

作者: 雪儿的小木屋 | 来源:发表于2016-07-22 23:43 被阅读69次

最近在公司做模块化拆分,算是告一段落;由于是我亲自参与设计,我想总结下。

我理解的模块化主要是便于管理代码,解耦,提高编译速度。这次组要做的是本地的模块化,网络端的模块化暂时不考虑。

现在分模块A-moduleA,模块B-moduleB,A的service-serviceA,B的service-serviceB。一个AppBus。

设计思路:总的思路是接口编程,利用protocol。创建protocolA:声明几个moduleA的服务方法;创建protocolB:声明几个moduleB的服务方法。让后在AppBus中引用protocolA.h 和 protocolB.h。serviceA遵循protocolA serviceB遵循protocolB,并实现全部方法。相当于service是各个module的外直接口。在AppBus中还有个注册服务的方法,把服务和响应的实现类绑定,用的时候直接取,绑定的是类名,不是实例,这样不会消耗太多的内存。实行注册的目的是方便管理。

+ (id)service:(Protocol *)serviceProtocol;

+ (BOOL)existService:(Protocol *)serviceProtocol;

+ (void)registerService:(Protocol *)serviceProtocol withImplementClass:(Class)implClass;

这样设计确实改善了代码的结构,方便了管理,效果还是不错的。目前的设计满足我们目前的需求,我们也会随着项目的改变不断优化,大家有什么好的建议多多留言交流。

相关文章

  • ES6学习笔记 II

    模块化 注意:模块化需要放到服务器环境使用模块化: 定义模块化如下 export export const a =...

  • 前端开发——模块化(css模块化开发)

    掌握模块化开发的思想是我们进行模块化开发的基础。他有以下几部分组成: 模块化开发的优势 css模块化 css模块化...

  • Node.js模块化学习

    模块化的基本概念Node.js 中模块化npm与包模块的加载机制 模块化的基本概念 什么是模块化 模块化是指解决一...

  • webpack基础笔记

    webpack基础 1.前端工程化 实际的前端开发: 模块化:(js的模块化,css的模块化,资源的模块化) 组件...

  • 模块化开发

    js模块化开发vue模块化开发

  • Vue前端工程化

    1.模块化的分类 A.浏览器端的模块化 B.服务器端的模块化 C.ES6模块化 小结:推荐使用ES6模块化,因为A...

  • 前端工程化

    1.模块化的分类 A.浏览器端的模块化 B.服务器端的模块化 C.ES6模块化 小结:推荐使用ES6模块化,因为A...

  • vue5

    es6新内容 class 解构赋值 扩展对象 模块化 什么是模块化 模块的作用 怎么实现模块化 模块化的标准 Co...

  • Vue基础教程之-组件核心概念(四)

    一、模块化 1.1 为什么需要模块化 没有模块化的世界:全局变量污染、难以管理的依赖。常见的模块化标准:Commo...

  • vue项目基建

    路由模块化 , 高频全局组件模块化 权限

网友评论

    本文标题:模块化

    本文链接:https://www.haomeiwen.com/subject/qjoijttx.html