使用react-navigation动态改变当前状态栏title

2018-05-17 14:38:17 浏览数 (2)

前言

正在使用react native构建自己的第二款APP,遇到了之前没有遇到的一些问题,就是点击下面的tabbar的时候,上面的状态栏问题无法动态改变。查阅了一些资料也没有头绪,最后去官网看了一下文档,解决后为有同样问题的大家分享一下步骤。

步骤

1. 重构navigationOptions使得可以接收参数

代码语言:javascript复制
static navigationOptions = ({ navigation }) => {
        const { params } = navigation.state;

        return {
            title: params ? params.title : '新闻',            #最关键的一句,剩下的属性自己可以自定义添加
                headerStyle: {
                    backgroundColor: '#fff',
                },
                headerTintColor: '#000',
                headerTitleStyle: {
                    flex: 1,
                    textAlign: 'center',
                    fontWeight: '20',
                },
        }
    };

2. 自定义方法,改变title的值

代码语言:javascript复制
_gotoPage(title) {
        this.props.navigation.setParams({title: title});
    }

使用onPress调用方法

代码语言:javascript复制
onPress={this._gotoPage.bind(this, '消息')}

或者方便起见,也可以不定义方法,直接在onPress中调用:

代码语言:javascript复制
onPress={() => this.props.navigation.setParams({title: '消息'})}

此时,点击下面labbar上面的title已经可以自动改变了。

0 人点赞