简介

本项目是一个学习类型的项目,主要是为了学习一些Android最新的思路和开发思想,工程按照模块化、组件化的开发思路进行开发,项目整体结构如下图。

高仿京东Android App,集成React-Native热更功能

项目代码整洁规范,结构清晰,使用Android最新的开发思想和技术,同时集成React-Native跨平台,主要是为了实验热更功能,涉及到的技术有如下一些:

  1. 使用kotlin语言开发,项目使用模块化开发,降低了耦合性;
  2. 网络使用 retrofit2 + okhttp3方式,进行了高度的封装;
  3. leakcanary 内存泄漏检测
  4. 基于MVI架构airbnb的Mavericks
  5. 本地mock
  6. alibaba ARouter
  7. 集成RN热更功能, 用户需要打开rn加载页面,rn工程请见

体验

  • Apk下载链接: Apk下载链接

  • Apk二维码

高仿京东Android App,集成React-Native热更功能

部分效果如下:

高仿京东Android App,集成React-Native热更功能

高仿京东Android App,集成React-Native热更功能

高仿京东Android App,集成React-Native热更功能

MVI架构

高仿京东Android App,集成React-Native热更功能
由于没有明确的状态管理标准,随着应用程序的增长或添加功能或事先没有计划的功能,视图渲染和业务逻辑可能会变得有点混乱,并且这种情况经常发生在Android应用开发过程中。可能你经常遇到状态管理导致业务逻辑和 UI 渲染的分工不明确,最终导致应用架构的混乱。而新提出的MVI架构,提倡一种单向数据流的设计思想,非常适合数据驱动型的UI展示项目。MVI的架构思想来源于前端,由于Model、View和Intent三部分组成。

  • Model:与其他MVVM中的Model不同的是,MVI的Model主要指UI状态(State)。当前界面展示的内容无非就是UI状态的一个快照:例如数据加载过程、控件位置等都是一种UI状态
  • View:与其他MVX中的View一致,可能是一个Activity、Fragment或者任意UI承载单元。MVI中的View通过订阅Intent的变化实现界面刷新(不是Activity的Intent、后面介绍)
  • Intent:此Intent不是Activity的Intent,用户的任何操作都被包装成Intent后发送给Model进行数据请求

用到的第三方库

功能
retrofit2 网络
okHttp3 网络
mavericks MVI框架
BaseRecyclerViewAdapterHelper 万能适配器
PhotoView 图片预览
ARouter 组件化路由
coil 图片加载
XPopup 弹窗组件
banner 滚动图
SmartRefreshLayout 智能下拉刷新框架
gson json解析
leakcanary 内存泄漏检测库

附件:github.com/GuoguoDad/j…