美文网首页React Nativern...vueReact Native
react-native-tab-navigator组件的基本使

react-native-tab-navigator组件的基本使

作者: 随遇而安_2750 | 来源:发表于2017-04-11 20:14 被阅读8492次

要做的效果很简单,如下图所示:

效果图

使用基本教程

1.引入组件
import TabNavigator from 'react-native-tab-navigator';

Github上的地址

2.render方法中返回:
render() {  
        return (  
            <View style={styles.container} >  
                <TabNavigator>  
                    <TabNavigator.Item  
                        selected={this.state.selectedTab === '电影'}  
                        title="电影"  
                        titleStyle={styles.tabText}  
                        selectedTitleStyle={styles.selectedTabText}  
                        renderIcon={() => <Image style={styles.icon} source={require("../images/movie_gray.png")} />}  
                        renderSelectedIcon={() => <Image style={styles.icon} source={require("../images/movie_red.png")} />}  
                        onPress={() => this.setState({ selectedTab: '电影' })}>  
                        <MoviePage/>  // 这里放入页面组件
                    </TabNavigator.Item>  
                    <TabNavigator.Item  
                        selected={this.state.selectedTab === '音乐'}  
                        title="音乐"  
                        titleStyle={styles.tabText}  
                        selectedTitleStyle={styles.selectedTabText}  
                        renderIcon={() => <Image style={styles.icon} source={require("../images/music_gray.png")} />}  
                        renderSelectedIcon={() => <Image style={styles.icon} source={require("../images/music_red.png")} />}  
                        onPress={() => this.setState({ selectedTab: '音乐' })}>  
                        <MusicPage />  
                    </TabNavigator.Item>  
                    <TabNavigator.Item  
                        selected={this.state.selectedTab === '图书'}  
                        title="图书"  
                        titleStyle={styles.tabText}  
                        selectedTitleStyle={styles.selectedTabText}  
                        renderIcon={() => <Image style={styles.icon} source={require("../images/book_gray.png")} />}  
                        renderSelectedIcon={() => <Image style={styles.icon} source={require("../images/book_red.png")} />}  
                        onPress={() => this.setState({ selectedTab: '图书' })}>  
                        <BookPage />  
                    </TabNavigator.Item> 
                    <TabNavigator.Item  
                        selected={this.state.selectedTab === '我的'}  
                        title="我的"  
                        titleStyle={styles.tabText}  
                        selectedTitleStyle={styles.selectedTabText}  
                        renderIcon={() => <Image style={styles.icon} source={require("../images/my_gray.png")} />}  
                        renderSelectedIcon={() => <Image style={styles.icon} source={require("../images/my_red.png")} />}  
                        onPress={() => this.setState({ selectedTab: '我的' })}>  
                        <MyPage />  
                    </TabNavigator.Item> 
                </TabNavigator>  
            </View>  
        );  
    }  
引入页面组件:
import MoviePage from './pages/MoviePage';
import MusicPage from './pages/MusicPage';
import BookPage from './pages/BookPage';
import MyPage from './pages/MyPage';
设置state状态机:
constructor(props){
    super(props);
    this.state = {
      selectedTab:'电影'
    }
}
引入基本样式:
const styles = StyleSheet.create({
  container:{
    flex:1,
    backgroundColor:'#fff'
  },
  tabText:{
    color:'#000000',
    fontSize:10
  },
  selectedTabText:{
    color:'#D81E06'
  },
  icon:{
    width:20,
    height:20
  }
})

这个时候效果已经出来了,我们继续抽象组件:

将每一个栏目抽出来放到一个统一的方法中:

_renderTabarItems(selectedTab,icon,selectedIcon,Component){
    return (
      <TabNavigator.Item
          selected={this.state.selectedTab === selectedTab}  
          title={selectedTab} 
          titleStyle={styles.tabText}  
          selectedTitleStyle={styles.selectedTabText}  
          renderIcon={() => <Image style={styles.icon} source={icon} />}  
          renderSelectedIcon={() => <Image style={styles.icon} source={selectedIcon} />}  
          onPress={() => this.setState({ selectedTab: selectedTab })}
      >
          <Component />
      </TabNavigator.Item>
    )

  }

此时,render方法中就直接引用四个方法即可:

render() {
    return (
      <View style={styles.container}>
        <TabNavigator>
          {this._renderTabarItems('电影',require('../img/movie_gray.png'),require('../img/movie_red.png'),MoviePage)}
          {this._renderTabarItems('音乐',require('../img/music_gray.png'),require('../img/music_red.png'),MusicPage)}
          {this._renderTabarItems('图书',require('../img/book_gray.png'),require('../img/book_red.png'),BookPage)}
          {this._renderTabarItems('我的',require('../img/my_gray.png'),require('../img/my_red.png'),MyPage)}
        </TabNavigator>
      </View>
    );
  }

至此,已经初步完成。

组件的属性集合:

Props

TabNavigator props

prop default type description
sceneStyle inherited object (style) 场景样式,即Tab页容器的样式,可按View的style设置
tabBarStyle inherited object (style) TabBar的样式,基本也可按照普通的style写法进行设置
tabBarShadowStyle inherited object (style) TabBar阴影的样式,不过对于扁平化的设计,这个属性应该用处不大
hidesTabTouch false boolean bool类型,即是否隐藏Tab按钮的按下效果

TabNavigator.Item props

prop default type description
renderIcon none function 即图标,但为function类型,所以这里需要用到Arrow Function
renderSelectedIcon none function 选中状态的图标,非必填,也是function类型
badgeText none string or number 即Tab右上角的提示文字,可为String或Number,类似QQ中Tab右上角的消息提示,非必填
renderBadge none function 提示角标渲染方式,function类型,类似render的使用,非必填
title none string 标题,String类型,非必填
titleStyle inherited style 标题样式,style类型,非必填
selectedTitleStyle none style 选中标题样式,style类型,非必填
tabStyle inherited style styling for tab
selected none boolean bool型,是否选中状态,可使用setState进行控制,默认false
onPress none function 即点击事件的回调函数,这里需要控制的是state
allowFontScaling false boolean bool型,是否允许字体缩放,默认false

相关文章

网友评论

  • f05c3018969e:我的demo调试后运行没报错,但是没有在模拟器里显示,这是为什么?
  • 从前有一个蕊蕊:你好,我想写一个,点击某个按钮跳转到对应的
    Tabbar怎么做???
  • aa2fa04e7317:你好,请问下,我集成了插件,demo写的跟你一样,但是不显示,不知道为啥,你用的rn是哪个版本的
  • 09c1d2662806: render() {
    return (

    <View>
    <TabNavigator>
    <TabNavigator.Item
    selected={this.state.tab == 'home'}
    title="首页"
    titleStyle={{color: '#eee', fontSize: 8}}
    selectedTitleStyle={{color: '#f00', fontSize: 8}}
    renderIcon={() => <Image style={{width: 40, height: 40}}
    source={require("../img/home_normal.png")}/>}
    renderSelectedIcon={() => <Image style={{width: 40, height: 40}}
    source={require("../img/home_checked.png")}/>}
    >
    <View>
    <Text>首页</Text>
    </View>
    </TabNavigator.Item>

    <TabNavigator.Item
    selected={this.state.tab == 'message'}
    title="消息"
    titleStyle={{color: '#eee', fontSize: 8}}
    selectedTitleStyle={{color: '#f00', fontSize: 8}}
    renderIcon={() => <Image style={{width: 40, height: 40}}
    source={require("../img/message_normal.png")}/>}
    renderSelectedIcon={() => <Image style={{width: 40, height: 40}}
    source={require("../img/message_checked.png")}/>}
    >
    <View>
    <Text>消息</Text>
    </View>
    </TabNavigator.Item>


    </TabNavigator>
    </View>
    );
    }
    *************************************************************
    你好, 我使用这个框架的时候遇到一个问题,我设置的icon都无法正常显示, 想请问下是什么原因呢?

本文标题:react-native-tab-navigator组件的基本使

本文链接:https://www.haomeiwen.com/subject/uhwuattx.html