React Navigation 4.x Tabbar

React Navigation 4.x

安装

4.x 版本从 react-navigation 中移除了各类导航器,同时还依赖了一些其他的包需要手动安装。

npm install react-navigation react-native-reanimated react-native-gesture-handler react-native-screens react-native-safe-area-context

安装一下 StackNavigator 和 BottomTabNavigator
npm install react-navigation-stack @react-native-community/masked-view react-navigation-tabs

Tabbar

const HomeTabSelectedIcon = require("./../assets/tabar/home.png");
const HomeTabUnSelectedIcon = require("./../assets/tabar/unhome.png");
const CartTabSelectedIcon = require("./../assets/tabar/cart.png");
const CartTabUnSelectedIcon = require("./../assets/tabar/uncart.png");
const MyTabSelectedIcon = require("./../assets/tabar/my.png");
const MyTabUnSelectedIcon = require("./../assets/tabar/unmy.png");


const TabNavigator = createBottomTabNavigator(
    {
        Home: {
            screen: Home,
            navigationOptions: {
                tabBarLabel: '首页',
                tabBarIcon:(({tintColor,focused}) => {
                    return(
                        <Image 
                            source={focused ? HomeTabSelectedIcon : HomeTabUnSelectedIcon}
                            style={styles.tabbarImage} 
                        />
                    )
                }),
            },
        },
        Cart: {
            screen: Cart,
            navigationOptions: {
                tabBarLabel: '购物车',
                tabBarIcon:(({tintColor,focused}) => {
                    return(
                        <Image 
                            source={focused ? CartTabSelectedIcon : CartTabUnSelectedIcon}
                            style={styles.tabbarImage} 
                        />
                    )
                }),
            },
        },
        User: {
            screen: User,
            navigationOptions: {
                tabBarLabel: '我的',
                tabBarIcon:(({tintColor,focused}) => {
                    return(
                        <Image 
                            source={focused ? MyTabSelectedIcon : MyTabUnSelectedIcon}
                            style={styles.tabbarImage} 
                        />
                    )
                }),
            },
        },
    },
    {
        defaultNavigationOptions: ({navigation}) => ({
            // tabBarIcon: ({focused, tintColor}) =>
            //     getTabBarIcon(navigation, focused, tintColor),
        }),
        tabBarOptions: {
            activeTintColor: '#333333',
            inactiveTintColor: '#333333',
        },
    }
);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值