react-navigation 之 TabNavigator

react-navigation 之 TabNavigator

上文已经说过StackNavigator,这篇文章说说TabNavigator,TabNavigator 与 StackNavigator 用法类似 语法相似

TabNavigator平台差异

Android IOS 默认显示效果不一样, Android tab默认在Top而IOS 默认在Buttom 不过我们可以设置参数改变这些默认效果

    const Presets = {
    iOSBottomTabs: {
        tabBarComponent: TabBarBottom,
        tabBarPosition: 'bottom',
        swipeEnabled: false,
        animationEnabled: false,
        lazy: false,
    },
    AndroidTopTabs: {
        tabBarComponent: TabBarTop,
        tabBarPosition: 'top',
        swipeEnabled: true,
        animationEnabled: true,
        lazy: false,
    },
};

参数说明


export default (
    routeConfigMap: NavigationRouteConfigMap,
    stackConfig: StackNavigatorConfig = {}
    )
    TabNavigator = (
    routeConfigs: NavigationRouteConfigMap,  //和StackNacigator 一样
    config: TabNavigatorConfig = {}
    )
   export type NavigationRouteConfigMap = {
  [routeName: string]: NavigationRouteConfig<*>,
};

routeConfigs (第一个参数)

都是基于 NavigationRouteConfigMap 但不同点在于 navigationOptions 里面的参数不一致

上文已经说过了StackNavigator 这里就不累述了

navigationOptionstabBar*系列都是设置TabNavigator的

  • title
  • tabBarLabel
  • tabBarIcon
  • tabBarVisible
export type NavigationScreenOptions = {
    title?: string,
    };
export type NavigationTabScreenOptions = NavigationScreenOptions & {
    tabBarIcon?:
        | React.Element<*>
        | ((options: { tintColor: ?string, focused: boolean }) => ?React.Element<
        *
        >),
    tabBarLabel?:
        | string
        | React.Element<*>
        | ((options: { tintColor: ?string, focused: boolean }) => ?React.Element<
        *
        >),
    tabBarVisible?: boolean,
    };

export type TabViewConfig = {
    tabBarComponent?: ReactClass<*>,
    tabBarPosition?: 'top' | 'bottom',
    tabBarOptions?: {},
    swipeEnabled?: boolean,
    animationEnabled?: boolean,
    lazy?: boolean,
};

通过上面源码可以知道:

  • title 是一个string类型的 会同时设置StackNavigator的title(当全局没有设置title属性时)
  • tabBarLabel 是既可以是string又可以是function(tintColor: ?string, focused: boolean)
  • tabBarIcon 是既可以是string又可以是function(tintColor: ?string, focused: boolean)
  • tabBarVisible boolean 类型 是否显示tabbar 默认显示

TabNavigatorConfig (第二个参数)

直接上源码

export type TabNavigatorConfig = {
    containerOptions?: void,
    } & NavigationTabRouterConfig &
    TabViewConfig;
    export type NavigationTabRouterConfig = {
        initialRouteName?: string,
        paths?: NavigationPathsConfig,
        navigationOptions?: NavigationScreenConfig<NavigationTabScreenOptions>,
        //以下是TabBar特有的
        order?: Array<string>, // todo: type these as the real route names rather than 'string'
        // Does the back button cause the router to switch to the initial tab
        backBehavior?: 'none' | 'initialRoute', // defaults `initialRoute`

export type TabViewConfig = {
        tabBarComponent?: ReactClass<*>,
        tabBarPosition?: 'top' | 'bottom',
        tabBarOptions?: {},
        swipeEnabled?: boolean,
        animationEnabled?: boolean,
        lazy?: boolean,
    };
};

{

  • initialRouteName 设置默认的页面组件
  • paths
  • navigationOptions
  • order
  • backBehavior 按 back 键是否跳转到第一个Tab(首页), none 为不跳转
  • tabBarPosition 设置tabbar的位置,iOS默认在底部,安卓默认在顶部。(属性值:'top','bottom')
  • swipeEnabled 是否允许在标签之间进行滑动。
  • animationEnabled 是否在更改标签时显示动画。
  • lazy
  • tabBarOptions 配置标签栏的一些属性

}

由以上源码可知
StackNavigator 区别多了 order , backBehavior,tabBarPosition,swipeEnabled,animationEnabled,lazy,backBehavior 还有 navigationOptions,tabBarOptions 的区别

tabBarOptions 配置标签栏的一些属性

ios  TabBarBottom.js
type DefaultProps = {
        activeTintColor: string,  // label和icon的前景色 活跃状态下(选中)。
        activeBackgroundColor: string,  //:label和icon的背景色 活跃状态下(选中) 。
        inactiveTintColor: string,    //label和icon的前景色 不活跃状态下(未选中)。
        inactiveBackgroundColor: string,  //label和icon的背景色 不活跃状态下(未选中)。
        showLabel: boolean,  // 是否显示label,默认开启。
    };

type Props = {
        activeTintColor: string,  // label和icon的前景色 活跃状态下(选中)。
        activeBackgroundColor: string,  //:label和icon的背景色 活跃状态下(选中) 。
        inactiveTintColor: string,      //label和icon的前景色 不活跃状态下(未选中)。
        inactiveBackgroundColor: string,  //label和icon的背景色 不活跃状态下(未选中)。
        position: Animated.Value,
        navigation: NavigationScreenProp<NavigationState, NavigationAction>,
        jumpToIndex: (index: number) => void,
        getLabel: (scene: TabScene) => ?(React.Element<*> | string),
        renderIcon: (scene: TabScene) => React.Element<*>,
        showLabel: boolean,   // 是否显示label,默认开启。
        style?: Style,       //tabbar的样式。
        labelStyle?: Style,   //label的样式。
        showIcon: boolean,      //是否显示图标,默认关闭。
    };

android  TabBarTop.js
type DefaultProps = {
        activeTintColor: string,  //label和icon的前景色 活跃状态下(选中) 。
        inactiveTintColor: string,  //label和icon的前景色 不活跃状态下(未选中)。
        showIcon: boolean,          //是否显示图标,默认关闭。
        showLabel: boolean,         // 是否显示label,默认开启。
        upperCaseLabel: boolean,   //是否使标签大写,默认为true。
    };
     indicatorStyle:标签指示器的样式对象(选项卡底部的行)。安卓底部会多出一条线,可以将height设置为0来暂时解决这个问题。
type Props = {
        activeTintColor: string,//label和icon的前景色 活跃状态下(选中) 。
        inactiveTintColor: string, //label和icon的前景色 不活跃状态下(未选中)。
        showIcon: boolean,          //是否显示图标,默认关闭。
        showLabel: boolean,          // 是否显示label,默认开启。
        upperCaseLabel: boolean, //是否使标签大写,默认为true。
        position: Animated.Value,
        navigation: NavigationScreenProp<NavigationState, NavigationAction>,
        getLabel: (scene: TabScene) => ?(React.Element<*> | string),
        renderIcon: (scene: TabScene) => React.Element<*>,
        labelStyle?: Style,     //label的样式。
        iconStyle?: Style,      //图标的样式。
    };
android  默认的 iconStyle 和 labelStyle
   icon: {
    height: 24,
    width: 24,
  },
  label: {
    textAlign: 'center',
    fontSize: 13,
    margin: 8,
    backgroundColor: 'transparent',
  },
  ios  默认的 iconStyle 和 labelStyle
   icon: {
    flexGrow: 1,
  },
  label: {
    textAlign: 'center',
    fontSize: 10,
    marginBottom: 1.5,
    backgroundColor: 'transparent',
  },

上述可知 Android 特有的属性 : indicatorStyle,iconStyle,upperCaseLabel

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容