npm install @react-navigation/drawer
官方文档
import React from 'react';
import { View, Text, Button } from 'react-native';
import {
DrawerContentScrollView,
createDrawerNavigator
} from '@react-navigation/drawer';
const Drawer = createDrawerNavigator();
const DrawerContent = (props) => {
return (
<DrawerContentScrollView>
<Text>自定义抽屉的内容</Text>
<Button title="跳转到详情" onPress={() => { props.navigation.navigate("Detail", { id: 123 }) }}></Button>
<Button title="跳转到个人中心" onPress={() => { props.navigation.navigate("Mine") }}></Button>
</DrawerContentScrollView>
);
}
// 主体页面
const Main = (props) => {
const goDetail = () => {
props.navigation.navigate("Detail", {
id: 123 //传递参数
})
}
return (
<View>
<Button title="打开抽屉" onPress={() => props.navigation.openDrawer()}></Button>
<Button title="跳转到详情" onPress={() => goDetail()}></Button>
<Button title="跳转到生命周期函数" onPress={() => props.navigation.navigate("Life")}></Button>
</View>
)
}
const Index = (props) => {
return (
<Drawer.Navigator drawerContent={(props) => <DrawerContent {...props} />} >
<Drawer.Screen name="drawer" component={Main} />
</Drawer.Navigator>
);
}
export default Index;