react-navigation 监听顶部导航栏点击/滑动状态

时间: 2019-03-13阅读: 45标签: react

问题描述:

使用createMaterialTopTabNavigator创建顶部导航栏,希望实现切换到指定的Tab再获取数据,查看官方文档只能找到tabBarOnPress 方法监听点击回调,但是无法监听滑动切换 

 

import React from 'react';
import {DeviceEventEmitter,View} from 'react-native';
import { createMaterialTopTabNavigator } from 'react-navigation';

export default class TestPage extends React.Component{
    constructor(props) {
            super(props);
            this.topTabList = ['All','Java', 'Javascript', 'PHP'];
           
    }
    _getTopBar() {
            let topBars = {}
            this.topTabList.forEach((item, index) => {
                topBars['TopBar_' + item] = {
                    screen: (props)=><ChildComponent {...props} tabName={item} InitTabName={this.topTabList[0]}/>,
                    navigationOptions: {
                        title: item,
                    }
                }
            })
            return topBars
    }
    getTopTabList(){
            if(!this.createTopNavigator){
                this.createTopNavigator = createMaterialTopTabNavigator(
                    this._getTopBar(),
                    {
                          //code...
                    }
                );
            }
            return this.createTopNavigator;
    }
        

    render(){
        const TopTabList = this.getTopTabList();
        // 在导航栏组件render位置使用onNavigationStateChange方法监听顶部导航切换-可监听滑动+点击
        return <View>
            <TopTabList
                onNavigationStateChange={(prevState, currentState)=>{
                     let {index} = currentState;
                     let TabName = currentState.routes[index].routeName;
                     TabName = TabName.split('_')[1];
                    //触发事件监听器,更新列表数据
                    //tip:如果希望切换已经加载过一次之后不重新获取数据,可以通过setParams设一个flag,判断flag是否需要触发监听器
                     DeviceEventEmitter.emit('TabChange',TabName);  
                }}
            />
        </View>
    }
}


class ChildComponent extends React.Component{
    constructor(props){
        super(props);
        this.tabName= this.props.tabName; //当前tabName
        this.InitTabName = this.props.InitTabName; //初始化列表
    }
    componentWillMount(){
         // 加载初始化Tab列表
            if(this.storeName===this.InitTabName){
                this.updateList();
            }
        // 监听Tab切换
            this.TopBarChangeListener = DeviceEventEmitter.addListener('TabChange',tabName=>{
                if(this.tabName===tabName){
                    //***更新列表***
                    this.updateList();
                }
            })
    }
    // 更新列表
    updateList(){
        let {navigation} = this.props;
        navigation.setParams({hasList:true});
        this.loadData(); 
    }
    loadData(){
        //***Send Request***
    }
    componentWillUnmount(){
        //移除事件监听器
        if(this.TopBarChangeListener){
                this.TopBarChangeListener.remove();
            }
        }
    }
    render(){
        return <View>
            {/* code... */}
        </View>
    }
}


必须要会的 50 个React 面试题

如果你是一位有抱负的前端程序员并准备面试,那么这篇文章很适合你。本文是你学习和面试 React 所需知识的完美指南。JavaScript 工具缓慢而稳定地在市场中扎根,对 React 的需求呈指数级增长。选择合适的技术来开发应用或网站变得越来越有挑战性

解决vscode 开发react 导入绝对路径 无法跳转的问题

相对路径可正常跳转,但是在webpack配置alias使用绝对路径后无法跳转.解决办法:需要添加一个jsconfig文件,如下:

react 源码之setState

与multirepo 相对。 monorepo是单代码仓库, 是把所有相关项目都集中在一个代码仓库中,每个module独立发布,每个module都有自己的依赖项(package.json),能够作为独立的npm package发布,只是源码放在一起维护。

怎样使用React Context API

React Context API 现在已经成为一个实验性功能,但是只有在 React 16.3.0 中才能用在生产中。本文将向你展示两个基本的 Web 商店应用程序,一个使用了 Context API 进行构建,另一个则不用。

React中使用CSS

在组件中直接使用style:不需要组件从外部引入css文件,直接在组件中书写。在组件中引入[name].css文件:需要在当前组件开头使用import引入css文件。在组件中引入[name].scss文件:引入react内部已经支持了后缀为scss的文件,所以只需要安装node-sass即可

create-react-app同时对多个框架(antd+antd-mobile)做按需加载的方法

在React项目开发中,经常需要引用一些实用的第三方框架。在使用一些比较庞大的第三方框架时,框架内的各种资源文件数量巨大,首先介绍下对单个框架做按需加载的方法

在react jsx中,为什么使用箭头函数和bind容易出现问题

因为()=>this.deleteUser(user.id)每执行一次就会生成一个新的函数,当然bind也是这样干的,所以在PureComponent的shallowCompare中认为onDeleteClick的值已经被修改,所以触发了重新渲染。看吧,使用箭头函数和bind会造成性能浪费,作为一个节约的程序员应该避免如此。

React-redux中connect的装饰器用法@connect

最近在琢磨react中的一些小技巧,这篇文章记录一下在redux中用装饰器来写connect。通常我们需要一个reducer和一个action,然后使用connect来包裹你的Component。

深入解析React中的元素、组件、实例和节点

eact 中的元素、组件、实例和节点,是React中关系密切的4个概念,也是很容易让React 初学者迷惑的4个概念。现在,我就来详细地介绍这4个概念,以及它们之间的联系和区别,满足喜欢咬文嚼字、刨根问底的同学的好奇心。

React中富文本编辑器的技术选型调研

富文本编辑器是项目中不可或缺的部分,目前市面上可以选择的富文本编辑器种类繁多,如何在项目中选择一款集轻量,美观,稳定,坑少,满足需求的富文本编辑器变成了团队中一个重要的问题。我对这两款富文本编辑器都进行了使用,并结合目前的项目需求进行了比较:react-quill、braft-editor

fly63.com版权所有,内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权,请与小编联系!情况属实本人将予以删除!

广告赞助文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯幽默笑话段子句子语录成语大全