iOS项目结构

Group 还是Feature

先上下前后两个项目的结构对比图:


1.png

旧的项目采用Group的方式,MVC结构,问题如下

  • 随着项目的复杂度不断上升,Controller,View文件夹变得异常庞大,定位某个具体业务对应的页面往往取决于文件名命名的好坏。
  • 具体业务的Controller,View,Model文件过于分散,通常无法在文件目录里面全部显示,不利于阅读,也不便于对应文件之间的跳转
  • 如果多人开发,则代码在文件夹层次必然相互干扰。

新的项目采用Feature方式,MVVC结构,优点如下:

  • 模块的区分便于理解产品的功能,文件的层次也基本反映了实际页面上的层次关系,便于快速定位到代码文件
  • 便于协同开发,各人仅需维护自己的Feature文件夹,进行单元测试,减少了合并冲突的问题
  • 同一Feature的Controller,View,Model, ViewModel在同一目录,便于阅读

具体

  • vender:第三方库,大部分第三方库均采用cocoapod方式引入,其他要源码引入的一般放在这里
  • Feature:业务具体模块,可以按功能进行划分,例如Login,More,Game
  • Manage:管理类,通常封装了对应用的某一块操作,例如网络请求管理模块,缓存管理模块,下载管理模块。
  • Utilite:工具模块,通常包括自定义的界面控件,对第三方库的简单封装类,通用工具函数类(与Manage主要区别在于Utilite复用性更强,而Manage则与项目耦合更紧密)
  • General:主要包含Additions,Macros文件夹,其中Macros包含
  1. NotificationMacro:通知宏定义文件
  2. AppMacro:应用内外网接口,APP_ClientId等和应用相关的宏
  3. UtilsMacro: 常用代码简写相关
  4. UrlMacro: web请求接口路径对应的宏,将请求地址统一管理,便于查找与更新
  5. EnumMacro:项目里面枚举一部分直接定义在所用枚举的文件头部,另一部分统一放在该文件,权衡的依据是如果枚举仅仅只跟界面相关,或者写了个通用类,反之,这些与业务相关的代码应该归到EnumMacro
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 项目结构主要在MVVM的基础上进行分层 Model负责定义数据模型等 ViewModel 负责沟通Model与Vi...
    iqqq阅读 204评论 0 0
  • 说两句项目结构和代码风格的重要性对于一个团队和项目来说不言而喻。首先项目结构清晰合理,方便产品的快速迭代以及提高团...
    君临浮世阅读 1,770评论 2 13
  • 这是我们开发中常用的项目结构, 由于我们通讯层采用的是ICE, 一种跨平台的通讯技术.而ICE会自动完成生成对应的...
    sixleaves阅读 871评论 1 3
  • 2016.3.25是《缘分》时隔32年在大陆上映的日子,今年哥哥60岁了,这是给他的献礼 看着电影那种神奇的感觉,...
    沁之女王阅读 248评论 0 0
  • 改变有两种:世界在你面前的改变,你在世界面前的改变。 最早我一直期待着前者,源于看得太多的批判社会的文章,他让我知...
    张静zjsx绍兴阅读 233评论 0 1