众所周知用React Native是可以开发跨平台的Android和iOS App。我们可以用React Native开发Android应用也可以开发iOS应用,那么如何让我们开发的React Native应用适配Android和iOS双平台呢?
在这篇文章中我将从布局、组件选择、图片、性能问题、Bugs等几个方面来谈一谈Android和iOS的适配问题。
布局
React Native在布局方面采用的是Flexbox,为了能让代码有更高复用性以及兼容性,我们可以将Android和iOS的样式尽量**一致。
善用Platform.OS
为了提高代码的兼容性,我们有时需要判断当前系统的平台,然后做一些适配。比如,我们在使用StatusBar做导航栏的时候,在iOS平台下根视图的位置默认情况下是占据状态栏的位置的,我们通常希望状态栏下面能显示一个导航栏,所以我们需要为StatusBar的外部容器设置一个高度:
<view style={{height: platform.os === 'ios' ? 20:0}}> <statusbar {...this.props.statusbar} > ;</statusbar {...this.props.statusbar} ></view style={{height: platform.os === 'ios' ? 20:0}}>
源代码https://git**.com/crazycodeboy/GitHubPopular/blob/master/js/common/NavigationBar.js
另外,在为视图设置阴影的时候我们需要用到Shadow Propsapi,而该api支持iOS平台,在Android平台下设置阴影我们需要用到elevation。
留意api doc的android或ios标识
并不是所有React Native的一些api或组件的一些属性和方法都兼容Android和iOS,在React Native的api doc中通常会在一些属性或方法的前面加上android或ios的字样来标识该属性或方法所支持的平台,如:
android renderToHardwareTextureAndroid bool ios shouldRasterizeIOS bool
在上述代码中,renderToHardwareTextureAndroid bool只支持Android平台,ios shouldRasterizeIOS bool只支持iOS平台,所有我们在使用这些带有标记的属性或方法的时候就需要考虑对于它们不兼容的平台我们是否需要做相应的适配了。
组件选择
React Native**到现在已经有相当丰富的组件来供开发者使用,那么从适配Android和iOS平台的角度如何甄选这些组件呢?
比如,我们要开发一款应用需要用到导航组件,在React Native组件中有NavigatorIOS与Navigator两个导航组件来供我们选择,从api doc中我们可以看出NavigatorIOS只支持iOS平台,Navigator则两个平台都支持。
所以如果我们要开发的应用需要适配Android和iOS,那么Navigator才是**的选择。
另外,类似的例子还有底部导航的TabBarIOS、ToolbarAndroid等。
心得:为了提高代码的复用性与兼容性建议大家在选择React Native组件的时候要多留意该组件是不是兼容Android和iOS,尽量选择Android和iOS平台都兼容的组件。
图片适配
开发一款应用少不了的需要用到图标。无论是Android还是iOS,现在不同分辨率的设备越来越多,我们希望这些图标能够适配不同分辨率的设备。为此我们需要为每个图标提供1x、2x、3x三种大小的尺寸,React Native会根据屏幕的分辨率来动态的选择显示不同尺寸的图片。比如:在img目录下有如下三种尺寸的check.png
└── img ├── check.png ├── check@2x.png └── check@3x.png
那么我们就可以通过下面的**来使用check.png:
<image source={require('. img="" check.png')} =""></image source={require('.>
提示:我们在使用具有不同分辨率的图标时,一定要引用**分辨率的图片如require('./img/check.png'),如果我们这样写require('./img/check@2x.png'),那么应用在不同分辨率的设备上都只会显示check@2x.png图片,也就无法达到图片自适配的效果。
性能问题
对于大多数想用React Native开发应用的开发者来说,都很关心React Native的性能问题,React Native和H5+WebView以及原生应用之间的性能对比是:WebView
提示:对性能要求较高的操作,比如:多线程、数据库操作、图片处理等,如果React Native组件或api无法**需求的话,我们可以借助原生模块来实现。
关于如何开发React Native原生模块大家可以参看双平台真实开发GitHub App React Native技术全面**。
Bugs
对于React Native的Bug我们可以提Issue与Pull Request,另外也可以关注React Native的版本发布releases,每次版本发布都会修复一些Bug,以及添加一些新的功能与api。