旅行喵 React Native 技术实践
旅行喵,是一款帮助用户快乐旅行的APP。
第一版的首打功能是行程定制,和景点信息介绍。大家可以在上面做非常简单的偏好选择,通过我们的智能算法生成适合自己的旅行路线。
为什么要用RN呢?
首先,相对于其它可以方便热更新的开发方式,RN在性能、可扩展性、代码维护上,有一定的优势。
其次,在人力资源利用上,相对于Native开发,也有一定的优势。我们最开始的时候只有3个人参与开发。后面为了让更多人熟悉RN这个技术,陆陆续续加了4、5个人进来。当然熟悉RN后又抽出去做其它项目了。基本上,新加进来的人,只要一周就可以独立开发。现在如果有一些简单的迭代,我自己一个人就可以快速完成iOS和Android两个端的维护。
RN的高扩展性,得益于它可以同时复用JS组件和Native组件。这样一来,大家现在手头上比较成熟完善的Native已经实现的功能就只需要简单引用,不用重复开发。
对Native组件的复用,RN有两种形式,一种是不带UI的原生模块。使用过程非常简单。三步就完成Native端原生模块的暴露,两步就完成JS端模块方法的调用。
另一种是带UI的原生UI组件。使用过程也十分简单。无非是在Native端增加一个View子类,和一个ViewManager子类。在JS端通常会把原生UI组件做成一个React组件再进行调用。
刚才大家看旅行喵的介绍,可能也能猜到,旅行喵上面有大量的图片。为了节省用户流量和提高图片加载速度,我们做了图片缓存的功能。在iOS和Android上分别通过原生UI组件的方式实现。
除了图片以外,我们还做了简单的数据缓存功能,主要用来存用户的登录信息,免除用户经常重复登录的麻烦。
RN刚开始出来的时候,动画功能很弱。经过多个版本迭代以后,现在已经可以完成很多简单的动画。
RN有两个动画组件。Animated适合做比较精细的视图动画控制。LayoutAnimation比较适合做过场动画。
我们在开发过程中,碰到了一个比较麻烦的手势响应传递的问题。列表,本身是支持上下滚动手势的。但,当我们在单元格上增加了左右滑动的手势后,发现单元格的手势把列表的手势响应完全拦载了。
后来,我们把小于45度角的手势定义为左右滑动,交给单元格响应。大于45度角的手势定义为上下滚动,交给列表响应。解决手势响应冲突的问题
旅行相关APP,自然少不了地图。
我们把第三方地图SDK做成原生UI组件。然后在JS端做成React组件。
这样就可以非常方便地和RN的标准组件嵌套实现功能页面。
为了更好地向用户展示景点信息。我们接入了RN视频组件react-native-video。
RN组件,使用非常方便,只需要一个命令就可以把它接入到工程。
我们在react-native-video的基础上,封装了加载视频预览图和播放按钮的功能。
旅行喵的用户除了可以使用APP自带的头像以外,还可以自定义自己的个性化的头像。
为了实现这个功能,我们接了一个图像选择器组件。它具有拍照和访问手机相册的功能。
选完图片,我们还要上传到服务器。我们接了一个文件上传RN组件。大家可以浏览一下右边代码,使用非常简单。
旅行喵为了最大限度地让用户尽可能无障碍体验APP的功能,我们绝大多数的操作,都不需要用户进行登录。那么用户在未登录状态下的操作,怎么在登录后和用户帐号绑定呢?
我们通过用户设备信息来进行绑定。
除了操作绑定以外,我们每个请求都会给后端带上用户设备信息,方便后台做相应的用户数据录入。
iOS平台不支持直接加载显示GIF图片,这导致RN在iOS平台也无法直接加载显示GIF图片。
我们在iOS平台上做了一个GIF加载原生UI组件。然后在JS端做成React组件。这样就可以非常方便地和RN的标准组件嵌套使用。
除了前面讲到的比较大的功能,RN里面也有很多比较小的但非常实用的功能、UI组件。
比如可以做倒计时的Timer组件。用来做验证码发送倒计时啊,或者其它有时间限制的功能,都非常好用。
RN刚开始出来的时候,很多人都担心屏幕适配方面会不会很麻烦。
我们开始做项目的时候,业界还没有什么成熟的方案提出来。
我们和设计师协商之后,决定以6 Plus为基准,通过一套机制把设计文档上标注的像素转换不同设备类型的像素点进行适配。
旅行喵上面有大量的图片加载。有部分图片相对大一点,有时候会出现加载慢,甚至加载失败的情况。
我们通过Image组件的接口对图片加载过程进行的监控。实现了默认图片,开始加载,加载成功,加载结束,加载失败后的重新加载的自定义处理。提升了整个APP图片加载的体验。
RN最开始的版本,崩溃率特别高,动不动就红屏。当然,现在迭代了这么多个版本后,稳定了很多。
如果你不想让APP在用户面前出现红屏,可以使用异常捕获组件ErrorUtils暂时解决。当然,你应该建立一套异常记录和上报的机制,保证自己事后可以去跟踪解决问题。
在开发阶段,我们可以在一些不应该走的分支里通过throw new Error主动抛出异常,来避免写出不够健壮的代码。在提交代码前,要记得把相应的throw去掉。
在开发的过程中,必然需要对代码进行调试。RN的调试也非常方便,在开发者菜单上开启浏览器调试就可以输出相应的Log信息。
我们比较习惯在Chrome上调试,在Sourse标签可以看到源码和Log输出,也可以打印相关的对象和变量,还能设置断点和单步执行。非常方便。
除了用模拟器调试之外,我们还可以进行真机调试。要保证手机和JS的服务在同一个WIFI下。
功能开发完了,除了在自己的开发机上运行测试。我们还可以给同事打个包,把JS文件安装到同事的手机上,让他们帮忙测试体验。
打离线包,只需要一个命令: react-natvie bundle。通过命令参数,指定入口文件、输出文件、平台、资源文件、是否开启开发模式。
打包过程非常快,旅行喵整个APP的JS文件,只需要18秒就可以打包完。
给同事装上JS文件后,如果我们想更新,怎么办呢?
我们有一套热更新的方案。分三步走。
第一步,上传打包好的jsbundle文件,并设置对应的JS版本号。后端维护一个根据设备类型对应JS版本的表。包括设备类型、版本号、jsbundle文件下载地址。客户端维护一个.plist文件,里面存储JS版本号和对应的jsbundle文件本地路径,还有当前版本号、回滚版本号、版本黑名单等。
第二步,在APP每次启动,客户端加载当前版本号对应路径的jsbundle文件,并且提供设备类型、当前版本号发JS文件更新请求。后端返回设备支持的最新版本号及jsbundle文件下载地址。客户端检查最新版本信息,如果最新版本不在黑名单,把最新版号设置为当前版本号。
第三步,在下次启动APP的时候,客户端加载最新版本,完成更新。如果APP启动崩溃,把当前版本号加入到黑名单,并回滚版本。
旅行喵 React Native 技术实践的更多相关文章
- react native 入门实践
上周末开始接触react native,版本为0.37,边学边看写了个demo,语法使用es6/7和jsx.准备分享一下这个过程.之前没有native开发和react的使用经验,不对之处烦请指出.希望 ...
- React Native技术做的一个项目“微笑阅读”
最近用React Native做了一个APP应用,有点心得: React Native确实比Hybrid应用渲染快,响应快,用户体验更好: React Native比原生简单多了,会Js就可以了,开发 ...
- React Native技术知识总结(不定期补充)
1.JSON https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/JSON JSON.pa ...
- React Native布局实践:开发京东client首页(三)——轮播图的实现
上篇文章中,我们一起构建了京东client的TabBar.在本文中.将继续向大家介绍京东client首页轮播图及其下发功能button的开发方法,如今就让我们開始吧! 1.相关控件调研 眼下在Gith ...
- 基于React Native的跨三端应用架构实践
作者|陈子涵 编辑|覃云 “一次编写, 到处运行”(Write once, run anywhere ) 是很多前端团队孜孜以求的目标.实现这个目标,不但能以最快的速度,将应用推广到各个渠道,而且还能 ...
- React Native开发技术周报1
(一).资讯 1.React Native 0.21版本发布,最新版本功能特点,修复的Bug可以看一下已翻译 重要:如果升级 Android 项目到这个版本一定要读! 我们简化了 Android 应用 ...
- 腾讯优测优分享 | 探索react native首屏渲染最佳实践
腾讯优测是专业的移动云测试平台,旗下的优分享不定时提供大量移动研发及测试相关的干货~ 此文主要与以下内容相关,希望对大家有帮助. react native给了我们使用javascript开发原生app ...
- 探索react native首屏渲染最佳实践
文 / 腾讯 龚麒 0.前言 react native给了我们使用javascript开发原生app的能力,在使用react native完成兴趣部落安卓端发现tab改造后,我们开始对由react n ...
- 为什么学习React Native三点原因
React Native不到两岁,兼容Android平台刚刚1年.我学习React Native其实也就不到1年,不算长,也不算短. Paul Graham在文章中写过:大多数人真正注意到你的时候,不 ...
随机推荐
- codevs 1557 热浪
传送门 题目描述 Description 德克萨斯纯朴的民眾们这个夏天正在遭受巨大的热浪!!!他们的德克萨斯长角牛吃起来不错,可是他们并不是很擅长生產富含奶油的乳製品.Farmer John此时以先天 ...
- Quartz1.8.5例子(三)
/* * Copyright 2005 - 2009 Terracotta, Inc. * * Licensed under the Apache License, Version 2.0 (the ...
- 40个Android问题
1. Android的四大组件是哪些,它们的作用? 答:Activity:Activity是Android程序与用户交互的窗口,是Android构造块中最基本的一种,它需要为保持各界面的状态,做很多持 ...
- prototype.js 源码解读(01)
prototype.js是一个设计的非常优雅且很有实用价值的js基础类库,其源码非常值得研究.研究它的源码不仅能提升个人水平,而且对你打下坚实的js基础也很有帮助.因本人技术水平有限,该解读仅供参考. ...
- Django Sqlite3 数据库向MySQL迁移
整合了两个URL而来.. 1,http://www.phodal.com/blog/django-mezzanine-sqlite3-migrate-mysql/ 2,http://www.ziqia ...
- 转-[Python 学习]2.5版yield之学习心得
在 shhgs 发布了关于< Py 2.5 what’s new 之 yield>之后,原来我不是特别关注 yield 的用法,因为对于2.3中加入的yield相对来说功能简单,它是作为一 ...
- python模块与包加载机制
模块的搜索路径: When a module named spam is imported, the interpreter searches for a file named spam.py in ...
- oracle索引再论
ORACLE中索引的数据结构有B树结构和位图结构. 我们通常用的普通索引.反向键索引.函数索引等都是B树结构的,是树状结构:位图结构则只有叶子节点. B树索引操作有唯一性扫描,范围扫描,快速索引全扫描 ...
- 【HDOJ】前三百留念
4个月不到的时间,终于刷到了HDOJ前三百.肯定还不够,好多基本的算法还不了解.还得继续学习.以此留念,假期目标是前一百.
- BZOJ1666: [Usaco2006 Oct]Another Cow Number Game 奶牛的数字游戏
1666: [Usaco2006 Oct]Another Cow Number Game 奶牛的数字游戏 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 5 ...