Android 组件化规范
修订记录
Date | Author | Version | Description | |
---|---|---|---|---|
2017-11-13 | wuzongbo | 0.0.1 | create | |
2018-03-19 | YasinYao | 0.0.2 | update |
目录
组件设计
设计要求
- 组件必须支持以application方式运行
- 每个组件最好能写写支持单元测试
一定要考虑多端通用(APP1、APP2、APP3、……)
命名规则
- 所有module包名必须为com.xxx.widge.mg{组件名}格式
- 所有的资源必须以“{组件名}_{资源名}”命名,防止资源ID冲突,例如mgbutton_activity_home
组件版本
- 每个组件统一使用gradle.properties统一管理版本
- 初始版本为:0.0.1,不要以1.0.0开始
- 测试版本格式:
0.0.1-SNAPSHOT
(SNAPSHOT 为快照版本) - 正式版本格式:0.0.1
组件依赖
- 依赖第三方组件,如果不必暴露第三方库,必须使用implementation依赖
禁止组件之间的依赖(很重要!!!)
,如果有这种需求那你该考虑设计成interface啦
build.gradle 实例
1 | apply plugin: 'com.android.library' |
组件发布
- 配置Maven
- 单个组件发布命令:./gradlew :{组件名}:uploadArchives
- 全部组件发布命令:./gradlew uploadArchives
组件使用
组件依赖
在工程级的build.gradle中增加如下代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14allprojects {
repositories {
maven { url 'http://192.168.60.96:8082/nexus/content/repositories/android-snapshots/' }
maven { url 'http://192.168.60.96:8082/nexus/content/repositories/android/' }
...
}
configurations.all {
//每隔10分钟检查动态版本的依赖是否更新
resolutionStrategy.cacheDynamicVersionsFor 10, 'minutes'
//每隔24小时检查远程依赖是否存在更新
resolutionStrategy.cacheChangingModulesFor 24, 'hours'
}
}依赖开发阶段的组件,版本号必须为快照版本(SNAPSHOT),这样有利于快速发布
1
implementation "com.xxx.widget:mgbanner:0.0.1-SNAPSHOT"
正式版依赖
1
implementation "com.xxx.widget:mgbanner:0.0.1"
常见问题
如何删除Gradle缓存
删除”/Users/wuzongbo/.gradle/caches/modules-2/files-2.1/{package}”目录,再同步Gradle文件(Sync Project with Gradle Files)
如何刷新Gradle版本
在Android studio中Terminal中输入命令:./gradlew –refresh-dependencies
页面跳转
组件之间使用路由地址跳转
1
MogoRouter.getInstance().build("mogopartner:///home").open(context);
组件内部跳转Builder跳转
1
RoomDetailsActivity_Router.intent(getContext()).roomId(123).start();
组件升级
因为此工程为所有android项目所引用,所以最好能兼容老的版本调用方式就兼容方法与样式
修改方法
比如在有一个方法A(int arg1,int arg2),我们要增加一个参数arg3,我们是不能再原来的方法是直接增加
必须要新增一个方法A(int arg1,int arg2,int arg3),然后再用这个老的方法去调用新的方法,并且给一个默认值
修改前1
2int a(int arg1,int arg2){
return arg1+arg2;
修改后1
2
3
4
5
6
7
8}
int a(int arg1,int arg2){
return a(arg1,arg2,0);
}
int a(int arg1,int arg2,int arg3){
return arg1+arg2+arg3;
}
修改样式
比如在有一个组件原来只是伙伴用的,颜色为蓝色, 现在要改为绿色,假设我们把这个颜色做活
那么我们做兼容的时候就需要指定一个默认颜色为蓝色,这样就做到兼容伙伴