Small插件化方案適用于將一個APK拆分為多個公共庫插件费封、業(yè)務模塊插件的場景场躯。
完美內(nèi)置所有插件支持內(nèi)置于宿主包中
高度透明插件編碼葬荷、布局編寫方式與獨立應用開發(fā)無異
插件代碼調(diào)試與整包開發(fā)無異極致剪裁對插件分離所有一切能分離的公共代碼芙粱、資源
無縫鏈接通過設定URI,宿主箱熬、本地化應用插件、本地化web插件狈邑、在線網(wǎng)頁城须,以及任何自定義的插件之間能夠相互調(diào)起與傳遞參數(shù)
跨平臺目前已支持Android、iOS以及html5插件米苹。并且三者之間可以通過同一套Javascript接口進行通信糕伐。
工程build.gradle中引入small,目前已發(fā)布gradle插件1.0.0-beta7版本蘸嘶,small組件1.1.0-beta4.
buildscript {
...
dependencies {
classpath 'com.android.tools.build:gradle:2.1.2'
classpath 'net.wequick.tools.build:gradle-small:1.0.0-beta7'
....
}
}
...
apply plugin: 'net.wequick.small'
small {
aarVersion = '1.1.0-beta4'
}
工程結構包括宿主工程app良瞧,業(yè)務模塊插件app.*,以及l(fā)ib.*公共庫插件工程亏较。如:
- 1.app 宿主工程
宿主工程中僅僅應用入口HostApp莺褒,啟動首屏展示LoadingActivity(不包含任何網(wǎng)絡加載邏輯,廣告圖片加載邏輯放在業(yè)務插件app.launch中)雪情。build.gradle中包含signingConfigs遵岩、buildTypes等,插件公共依賴可放到dependencies中巡通,不會打包到插件中尘执。
記得在assets中bundle.json文件配置插件包名和路由rules,否則small將找不到對應插件宴凉。
- 2.app.業(yè)務模塊*
業(yè)務模塊之間互相獨立誊锭,通過small來管理跳轉和fragment的獲取。業(yè)務模塊包含自己的APIService(網(wǎng)絡請求使用lib.net,底層是retroifit+okhttp)弥锄、UI(Activity丧靡、Fragment蟆沫、View、Adapter)温治、Model饭庞、Application。
Small Activity跳轉
Small.openUri("main", LaunchActivity.this);
Small獲取Fragment
BaseFragment fragment = (BaseFragment)Small.createObject("fragment-v4", "community/community", MainActivity.this);
- 3.lib.模塊*
lib模塊的引用最好在宿主工程中也保留一份熬荆,這樣不會打包到插件中舟山,可以使最后只保留一份引用。Account也可以做成lib卤恳,供其他app插件調(diào)用累盗。
lib.style中包含通用的動畫、顏色突琳、規(guī)格若债、尺寸、主題本今。
lib.utils放置一些通用help拆座、utils,依賴style(dialog主題)冠息。
lib.config 應用的配置信息挪凑,版本號、包名逛艰、系統(tǒng)信息等躏碳。
lib.constant 暫時放置一些常量、枚舉散怖、key菇绵、id等。
lib.analytics統(tǒng)計API
lib.net 網(wǎng)絡請求框架镇眷,retroifit+okhttp咬最,處理token錯誤等全局錯誤。
lib.base放置Activity欠动、Application永乌、Fragment等的基類。
lib.router Small的uri特殊處理
- 4.其他第三方模塊和aar
其他依賴最好通過私有maven倉庫管理具伍。
jni_plugin用來存放一些so文件翅雏,以及jni接口。
jsbridge--webview和native交互的一個庫人芽,參考
https://github.com/gzsll/WebViewJavascriptBridge望几。