Android Qzone 6.1版本在情侣空间涉水React Native,以动态插件方式将情侣空间进行React Natived的改造。在情侣空间基础上,Android Qzone 6.2版本以融合的方式将话题圈进行React Native改造。本文主要讲述话题圈的开发改造流程,相关数据对比及性能优化,本次改造ReactNative基于15Release。
一、Android侧项目整体开发流程
二、ReactNative改造后话题圈整体流程
三、ReactNative性能优化之路本次版本开发周期较赶,
加上视频组件本身相对复杂,融入ReactNative耗时较多,部分优化规划在二期实施。
1、包精简版本对比:
情侣独立
插件:7.2m。
话题圈:本次ReactNative框架移植入Qzone整体仅加大了3.2m。
主要优化点:
1.去除了小平台so库。
2.复用Qzone support jar。
二期规划:
1.在Qzone与ReactNative中间加Adapter,使ReactNative适配Qzone本身网络库及图片库,可以废弃ReactNative框架的okhttp库及fresco库,减少包大小。
2、首屏加速与启动速度
版本对比:
ReactNative改造后话题圈在wifi及缓存优化下,首屏相比H5快约 108ms,并且由于jsbundle缓存到本地,并且可以实现离线访问。
1.更改源码,新增预初始化接口,在Qzone Feeds渲染完成预加载ReactNative上下文。
2.首屏数据需要等前端走网络请求拉取存本地,H5优先采用本地数据渲染。
优化前后流程对比:
优化前.png
优化后.png
4、内存版本对比:
情侣空间:无内存泄漏及浪费内存情况,比H5版本多约20%。
话题圈:无内存泄漏及浪费内存情况,与H5版本基本持平。
话题圈详细数据:
主要优化点:
1.JS层使Listview控件渲染数据,废弃使用ScrollView控件。
2.视频VideoView拆分,VideoCover交由H5实现,Native对应Fresco管理,MideaPlayer由Native实现。
二期规划:
目前官方暂提供的listview未采用item复用逻辑,仅在item不可见时置空,RecyclerView仍是Test控件只
支持横向滚动。listview
性能仍需提高,下版本规划实现高可用RecyclerView。
四、ReactNative话题圈与H5话题圈整体数据对比
目前ReactNative在Web与Native通信耗时明显优于webview的jsbridge方式(console.log),在高中端机上如FPS及cpu上表现优于H5,但是从全局来看,目前crash,内存,FPS,首屏等均有优化空间,下面是整体对比数据。
五、写在最后**React Native因你参与会更精彩,希望2016年能将更多的开发者加入React Native阵营,让更多的业务都是 Web的版本节奏,Native的流畅顺滑。后续关于ReactNative的
文章我们会持续推送,快关注我们的官方公众帐号吧。下面
二维码直达Android Qzone 6.2版本 下载安装,"发现" Tab 中的话题圈即是使用ReactNative改造后的,快下载体验吧。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。