React Native 全栈开发实战班 - 核心组件与导航
在移动应用中,导航是用户界面设计的重要组成部分。React Native 本身并不提供内置的导航解决方案,因此我们通常使用第三方库来实现导航功能。React Navigation 是目前最流行的 React Native 导航库,它提供了简单易用的 API 来管理应用的导航栈、路由和页面跳转。
本章节将介绍 React Navigation 的基本概念、安装步骤以及如何使用 React Navigation 实现基本的导航功能。
2.1 React Navigation 简介
React Navigation 是一个强大的导航库,支持多种导航模式,包括:
- Stack Navigator(堆栈导航器)
- Tab Navigator(标签导航器)
- Drawer Navigator(抽屉导航器)
- Bottom Tabs Navigator(底部标签导航器)
- Native Stack Navigator(原生堆栈导航器)
React Navigation 的优势:
- 跨平台支持: 支持 iOS 和 Android 平台。
- 高度可定制: 可以自定义导航栏、动画、样式等。
- 社区支持: 拥有庞大的社区和丰富的插件生态。
- 易于使用: 提供简洁的 API,易于上手。
2.2 安装 React Navigation
首先,需要安装 React Navigation 及其依赖包。
步骤:
-
安装 React Navigation 核心包:
npm install @react-navigation/native
-
安装堆栈导航器:
npm install @react-navigation/native-stack
-
安装标签导航器(可选):
如果需要使用标签导航器,可以安装:
npm install @react-navigation/bottom-tabs
-
安装依赖包:
React Navigation 依赖于一些第三方库,如
react-native-screens
和react-native-safe-area-context
。npm install react-native-screens react-native-safe-area-context
-
链接原生依赖(如果使用 React Native CLI):
对于 React Native 0.60 及以上版本,自动链接原生依赖。
对于 React Native 0.59 及以下版本,需要手动链接:
react-native link react-native-screens react-native link react-native-safe-area-context
-
配置 iOS 项目:
如果使用 CocoaPods,需要安装 Pod 依赖:
cd ios pod install cd ..
2.3 基本导航示例
以下是一个使用 React Navigation 实现基本堆栈导航的示例。
步骤:
-
设置导航容器:
使用
NavigationContainer
包裹整个应用。// App.js import React from 'react'; import { NavigationContainer } from '@react-navigation/native'; const App = () => { return ( <NavigationContainer> {/* 导航器组件 */} </NavigationContainer> ); }; export default App;
-
创建堆栈导航器:
使用
createNativeStackNavigator
创建堆栈导航器,并定义路由。// App.js import React from 'react'; import { NavigationContainer } from '@react-navigation/native'; import { createNativeStackNavigator } from '@react-navigation/native-stack'; import HomeScreen from './screens/HomeScreen'; import DetailsScreen from './screens/DetailsScreen'; const Stack = createNativeStackNavigator(); const App = () => { return ( <NavigationContainer> <Stack.Navigator initialRouteName="Home"> <Stack.Screen name="Home" component={HomeScreen} /> <Stack.Screen name="Details" component={DetailsScreen} /> </Stack.Navigator> </NavigationContainer> ); }; export default App;
-
创建页面组件:
创建
HomeScreen
和DetailsScreen
页面组件。// screens/HomeScreen.js import React from 'react'; import { View, Text, Button, StyleSheet } from 'react-native'; const HomeScreen = ({ navigation }) => { return ( <View style={styles.container}> <Text style={styles.text}>Home Screen</Text> <Button title="Go to Details" onPress={() => navigation.navigate('Details')} /> </View> ); }; const styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', alignItems: 'center', }, text: { fontSize: 18, marginBottom: 20, }, }); export default HomeScreen;
// screens/DetailsScreen.js import React from 'react'; import { View, Text, StyleSheet } from 'react-native'; const DetailsScreen = () => { return ( <View style={styles.container}> <Text style={styles.text}>Details Screen</Text> </View> ); }; const styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', alignItems: 'center', }, text: { fontSize: 18, }, }); export default DetailsScreen;
解释:
NavigationContainer
是 React Navigation 的根组件,包裹整个应用。createNativeStackNavigator
创建一个堆栈导航器,并定义路由。Stack.Screen
定义每个路由对应的页面组件。navigation.navigate('Details')
用于导航到Details
页面。
2.4 导航进阶
2.4.1 页面跳转
React Navigation 提供了多种导航方法:
navigation.navigate('RouteName')
:导航到指定路由。navigation.goBack()
:返回上一页。navigation.push('RouteName')
:在堆栈中添加一个新页面。navigation.replace('RouteName')
:替换当前页面。
示例:
// 跳转到 Details 页面
navigation.navigate('Details');
// 返回上一页
navigation.goBack();
// 在堆栈中添加一个新页面
navigation.push('Details');
// 替换当前页面
navigation.replace('Details');
2.4.2 传递参数
可以通过 navigate
方法传递参数到目标页面。
示例:
// 传递参数
navigation.navigate('Details', {
itemId: 42,
otherParam: 'anything you want here',
});
在目标页面中,可以通过 route.params
接收参数。
// screens/DetailsScreen.js
import React from 'react';
import { View, Text, StyleSheet } from 'react-native';
const DetailsScreen = ({ route }) => {
const { itemId, otherParam } = route.params;
return (
<View style={styles.container}>
<Text style={styles.text}>Details Screen</Text>
<Text>Item ID: {itemId}</Text>
<Text>Other Param: {otherParam}</Text>
</View>
);
};
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
},
text: {
fontSize: 18,
marginBottom: 10,
},
});
export default DetailsScreen;
2.4.3 标签导航
标签导航器(Tab Navigator)用于在应用底部或顶部显示标签栏,实现页面切换。
安装标签导航器:
npm install @react-navigation/bottom-tabs
示例:
// App.js
import React from 'react';
import { NavigationContainer } from '@react-navigation/native';
import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
import HomeScreen from './screens/HomeScreen';
import SettingsScreen from './screens/SettingsScreen';
const Tab = createBottomTabNavigator();
const App = () => {
return (
<NavigationContainer>
<Tab.Navigator>
<Tab.Screen name="Home" component={HomeScreen} />
<Tab.Screen name="Settings" component={SettingsScreen} />
</Tab.Navigator>
</NavigationContainer>
);
};
export default App;
解释:
createBottomTabNavigator
创建一个标签导航器。Tab.Screen
定义每个标签对应的页面组件。