平台特定代码
在构建跨平台应用时,你会希望尽可能多地复用代码。可能会出现代码需要不同的情况,例如你可能想要为 Android 和 iOS 实现独立的视觉组件。
React Native 提供了两种方法来组织你的代码并按平台分离:
- 使用
Platform模块。 - 使用 平台特定文件扩展名。
某些组件可能具有仅在一个平台上有效的属性。所有这些属性都用 @platform 标注,并在网站上旁边有一个小徽章。
Platform 模块
React Native 提供了一个模块来检测应用运行的平台。你可以使用检测逻辑来实现平台特定的代码。当只有组件的小部分是平台特定的时,使用此选项。
import {Platform, StyleSheet} from 'react-native';
const styles = StyleSheet.create({
height: Platform.OS === 'ios' ? 200 : 100,
});
Platform.OS 在 iOS 上运行时将为 ios,在 Android 上运行时将为 android。
还有一个可用的 Platform.select 方法,给定一个键可以是 'ios' | 'android' | 'native' | 'default' 之一的对象,它会返回最适合你当前运行平台的值。也就是说,如果你在手机上运行,ios 和 android 键将优先。如果未指定这些,则将使用 native 键,然后是 default 键。
import {Platform, StyleSheet} from 'react-native';
const styles = StyleSheet.create({
container: {
flex: 1,
...Platform.select({
ios: {
backgroundColor: 'red',
},
android: {
backgroundColor: 'green',
},
default: {
// 其他平台,例如 web
backgroundColor: 'blue',
},
}),
},
});
这将导致容器在所有平台上具有 flex: 1,在 iOS 上具有红色背景色,在 Android 上具有绿色背景色,在其他平台上具有蓝色背景色。
由于它接受 any 值,你也可以使用它来返回平台特定的组件,如下所示:
const Component = Platform.select({
ios: () => require('ComponentIOS'),
android: () => require('ComponentAndroid'),
})();
<Component />;
const Component = Platform.select({
native: () => require('ComponentForNative'),
default: () => require('ComponentForWeb'),
})();
<Component />;
检测 Android 版本 Android
在 Android 上,Platform 模块也可用于检测应用运行的 Android 平台版本:
import {Platform} from 'react-native';
if (Platform.Version === 25) {
console.log('Running on Nougat!');
}
注意:Version 设置为 Android API 版本而不是 Android OS 版本。要查找映射,请参阅 Android 版本历史。
检测 iOS 版本 iOS
在 iOS 上,Version 是 -[UIDevice systemVersion] 的结果,它是一个包含操作系统当前版本的字符串。系统版本的一个示例是 "10.3"。例如,要检测 iOS 上的主版本号:
import {Platform} from 'react-native';
const majorVersionIOS = parseInt(Platform.Version, 10);
if (majorVersionIOS <= 9) {
console.log('Work around a change in behavior');
}
平台特定扩展
当你的平台特定代码更复杂时,你应该考虑将代码拆分到单独的文件中。React Native 会检测文件是否具有 .ios. 或 .android. 扩展名,并在其他组件需要时加载相关的平台文件。
例如,假设你的项目中有以下文件:
BigButton.ios.js
BigButton.android.js
然后你可以如下导入组件:
import BigButton from './BigButton';
React Native 将根据运行平台自动选取正确的文件。
Native 特定扩展(即与 NodeJS 和 Web 共享代码)
当模块需要在 NodeJS/Web 和 React Native 之间共享但没有 Android/iOS 差异时,你也可以使用 .native.js 扩展名。这对于在 React Native 和 ReactJS 之间共享通用代码的项目特别有用。
例如,假设你的项目中有以下文件:
Container.js # 由 webpack、Rollup 或任何其他 Web 打包工具选取
Container.native.js # 由 React Native 打包工具选取,适用于 Android 和 iOS (Metro)
你仍然可以导入它而不带 .native 扩展名,如下所示:
import Container from './Container';
专业提示: 配置你的 Web 打包器以忽略 .native.js 扩展名,以避免在生产打包中包含未使用的代码,从而减小最终打包大小。