温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

react-native-tab-navigator组件怎么用

发布时间:2021-07-21 09:32:54 来源:亿速云 阅读:194 作者:小新 栏目:web开发

小编给大家分享一下react-native-tab-navigator组件怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

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

react-native-tab-navigator组件怎么用

使用基本教程

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

propdefaulttypedescription
sceneStyleinheritedobject (style)场景样式,即Tab页容器的样式,可按View的style设置
tabBarStyleinheritedobject (style)TabBar的样式,基本也可按照普通的style写法进行设置
tabBarShadowStyleinheritedobject (style)TabBar阴影的样式,不过对于扁平化的设计,这个属性应该用处不大
hidesTabTouchfalsebooleanbool类型,即是否隐藏Tab按钮的按下效果

TabNavigator.Item props

propdefaulttypedescription
renderIconnonefunction即图标,但为function类型,所以这里需要用到Arrow Function
renderSelectedIconnonefunction选中状态的图标,非必填,也是function类型
badgeTextnonestring or number即Tab右上角的提示文字,可为String或Number,类似QQ中Tab右上角的消息提示,非必填
renderBadgenonefunction提示角标渲染方式,function类型,类似render的使用,非必填
titlenonestring标题,String类型,非必填
titleStyleinheritedstyle标题样式,style类型,非必填
selectedTitleStylenonestyle选中标题样式,style类型,非必填
tabStyleinheritedstylestyling for tab
selectednonebooleanbool型,是否选中状态,可使用setState进行控制,默认false
onPressnonefunction即点击事件的回调函数,这里需要控制的是state
allowFontScalingfalsebooleanbool型,是否允许字体缩放,默认false

以上是“react-native-tab-navigator组件怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI