android组件化开发 pdf app组件化开发_ide


简介

为什么要组件化开发?

在项目庞大,业务复杂的app下,如果不采用组件化的开发方式,或许会因为功能区分不明显,导致各个功能块、页面相互依赖,相互调用太多导致耦合度高。而采用组件化可以使我们的模块有明显的划分,强制将我们的功能耦合度降低。

组件化开发项目结构

组件化就是要将项目的各个功能拆成多个模块,就比如抖音来说,有视频播放的app主模块,登录注册模块,视频选择发布模块,相机拍摄特效模块等。

android组件化开发 pdf app组件化开发_组件化_02

演示效果:

android组件化开发 pdf app组件化开发_android组件化开发 pdf_03

项目结构

示例项目模块结构图:

分为app模块,base模块,登录模块。

android组件化开发 pdf app组件化开发_项目结构_04

组件化开发Arouter配置

1.在libbase模块的gradle文件引入arouter库:

   api 'com.alibaba:arouter-api:1.2.1'
    annotationProcessor 'com.alibaba:arouter-compiler:1.1.2'


2.在其他模块gradle文件中加入

annotationProcessor 'com.alibaba:arouter-compiler:1.1.2'


3.在各个模块的gradle文件的defaultConfig标签下加入

javaCompileOptions {annotationProcessorOptions {arguments = [ moduleName : project.getName() ]
            }
        }


4.在application中初始化Arouter配置:

if (AppConfig.isDebug) {ARouter.openDebug();ARouter.openLog();
        }ARouter.init(this);

5.设置跳转路径配置类:

public class RouterPath {public static final String ROUTER_LOGIN = "/login/loginPage";
}

6.在需要跳转到的类上设置跳转路径:

@Route(path = RouterPath.ROUTER_LOGIN)public class LoginActivity extends AppCompatActivity {
}

7.各个模块依赖base模块,app模块依赖login模块。

8.从app模块跳转到登录模块:build()方法传入跳转的路径withxxx()设置跳转的传参.withTransition()设置进入退出的动画

ARouter.getInstance().build(RouterPath.ROUTER_LOGIN).withString("phone", "18201038278").withTransition(R.anim.dialog_enter, R.anim.dialog_exit).navigation();

传值类型包括:

android组件化开发 pdf app组件化开发_android pod 组件化_05

各个模块其他配置

公共模块的application是application类的基类:

/**
 * create by libo
 * create on 2018/12/26
 * description 公共模块基类Application
 */public class BaseApplication extends Application {public static BaseApplication instance;@Overridepublic void onCreate() {super.onCreate();
        instance = this;
        init();
    }private void init() {//组件化ARouter初始化if (AppConfig.isDebug) {
            ARouter.openDebug();
            ARouter.openLog();
        }
        ARouter.init(this);
    }
}


其他模块的application继承基类application:

public class MyApplication extends BaseApplication {@Overridepublic void onCreate() {super.onCreate();
    }
}

其他配置:

权限等配置写在app模块下的AndroidManifest.xml中;字符串、颜色、尺寸资源等写在公共模块下。

Butterknife在子模块中的配置

1.在base模块的gradle文件中加入库引入:

api 'com.jakewharton:butterknife:8.5.1'
    annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'


2.在其他各个模块的gradle文件中加入:

annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'


3.在子模块(除了app模块)中的gradle文件的顶部加入使用butterknife插件配置:

apply plugin: 'com.jakewharton.butterknife'


4.在项目的gradle文件中dependencies标签下加入插件配置:

classpath 'com.jakewharton:butterknife-gradle-plugin:8.5.1'

子模块中使用方式:

绑定控件需要将原本R来引入的改为R2来引入。

@BindView(R2.id.tv_login_code)
    TextView tvLoginCode;
    @BindView(R2.id.et_login_phone)
    EditText etLoginPhone;
    @BindView(R2.id.btn_login_next)
    Button btnLoginNext;


事件绑定:原来用switch匹配的需要改为用if else匹配。

@OnClick(R2.id.btn_login_next)void onClick(View view) {if (view.getId() == R.id.btn_login_next) {
            Toast.makeText(getApplicationContext(), getString(R.string.login), Toast.LENGTH_SHORT).show();
        }
    }




注意事项:

1.声明各个跳转的path,path需要以"/"开头,并且至少2个,否则会报
ARouter::Extract the default group failed, the path must be start with '/' and contain more than 2 '/'!

2.需要跨module使用的依赖需要用api,而不是implementation,否则base模块引入库其他模块使用不了。

3.application模块要跳转到子模块,如果子模块也是application状态,则Arouter跳转不生效,需要将application配置改为library配置。

Github地址:

https://github.com/18380438200/MyRouterProject

—————END—————