React-Native中createMaterialTopTabNavigator的高级使用

React-Native中createMaterialTopTabNavigator的高级使用

createMaterialTopTabNavigator作为react-native中重要的Tab组件,日常中使用频率很高,如果优雅的实现一些高级组件的功能,降低render刷新频率,事件方法绑定,我将与你一起讨论学习createMaterialTopTabNavigator的高级使用

  1. TabNavigator如何将数据传递给子组件
  2. TabNavigator如何与子组件直接方法传递
  3. TabNavigator子组件直接如何切换
  4. TabNavigator如何切入指定的Screen(界面)
简单的实现一个TabNavigator

目标:实现一个(可使用)和(不可使用)的tab,并显示可使用和不可使用的数量,如:可使用(10),不可使用(20)

TabNavigator.png
constructor(props) {
        super(props)
        this.state = {
            used: '可使用',
            unused: '不可使用',
            isUnused: false,            //指定界面是否是不可使用,默认可使用界面
            unavailablePackageList: [], //不可使用list
            availablePackageList: [],   //可使用list
        }
    }
render() {

        let unNumber = this.state.unavailablePackageList ? this.state.unavailablePackageList.length : '0'
        let number = this.state.availablePackageList ? this.state.availablePackageList.length : '0'

        const AppNavigator = createMaterialTopTabNavigator(
            {
                Used: {
                    screen: UseScreen,
                    navigationOptions: {
                        title: this.state.used + '(' + number + ')',
                    }
                },
                Unused: {
                    screen: UnusedScreen,
                    navigationOptions: {
                        title: this.state.unused + '(' + unNumber + ')',
                    }
                },
            }, {
                tabBarPosition: 'top',       
                swipeEnabled: true,           
                lazy: false,                 
                animationEnabled: true,     
                order: ['Used', 'Unused'],
                initialRouteName: this.state.isUnused ? 'Unused' : 'Used',
                tabBarOptions: {
                    showIcon: false,
                    style: {
                        backgroundColor: 'white',
                        elevation: 0,
                        borderBottomColor: Colors.timelineLightGrayColor,
                        borderBottomWidth: Dimens.dx_1,
                    },
                    activeTintColor: Colors.textCouponBlueColor,
                    inactiveTintColor: Colors.black,
                    indicatorStyle: {
                        backgroundColor: Colors.textCouponBlueColor,
                        height: Dimens.dx_8,
                        width: Dimens.dx_200,
                        marginLeft: (screenWidth / 2.0 - Dimens.dx_200) / 2.0
                    },
                    labelStyle: {
                        fontSize: Dimens.dx_46,
                        lineHeight: Dimens.dx_65,

                    }
                },         )
        const AppContainer = createAppContainer(AppNavigator)

        return (
            <AppContainer/>
        )
    }
        

毫无疑问,如果只是这么简单的功能,我们已经完成了,那么标题怎么能叫高级使用尼?那么问题来了

数据子组件如何使用的?事件子组件如何交互的?


defaultNavigationOptions: ({navigation}) => {
                    if (navigation.state.routeName === 'Unused') {
                        navigation.state.params = {
                            unavailablePackageList: this.state.unavailablePackageList,
                            exchangePackageIntegral: this.exchangePackageIntegral.bind(this),
                            selectOrderPackageUpdate: this.selectOrderPackageUpdate.bind(this)
                        }
                    } else {
                        navigation.state.params = {
                            availablePackageList: this.state.availablePackageList,
                            selectOrderPackageUpdate: this.selectOrderPackageUpdate.bind(this),
                            unUsePackageIntegral: this.unUsePackageIntegral.bind(this),
                            exchangePackageIntegral: this.exchangePackageIntegral.bind(this)
                        }
                    }
                }
            }
            
在tabOptions{}后,添加defaultNavigationOptions,将需要传递的数据,
如:不可用和可使用list存放在navigation.state.params里面,
包括事件绑定exchangePackageIntegral,如果用户选择了【去使用】,我们就可以在组件里去使用

selectOrderPackageUpdate(item) {
        this.props.onSelected(item)
   }

如何知道点击了(可使用)和(不可使用)tab的尼?

在对应子组件里调用navigationOptions

static navigationOptions = ({navigation}) => ({
        tabBarOnPress: (event) => {
            event.defaultHandler();
            console.log('点击了Unused')
        }
    })

在对应子组件里获取数据

 this.state.availablePackageList = this.props.navigation.state.params.availablePackageList;

在对应子组件里调用事件

可以有参数,可以无参数,就可以实现方法的回调了

this.props.navigation.state.params.selectOrderPackageUpdate(this.state.packageInfo)

子组件直接如何切换?

需求:用户在可用tab下兑换了一张不可用的券码,兑换成功后需要将所在可用界面跳转到不可用界面

直接执行

this.props.navigation.navigate('UnusedScreen')

如何切入指定的界面?

这个比较简单了,开始的时候设置好initialRouteName,根据isUnused来判断当前活动的界面

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