一张跟内容完全关系的图
一个带有TabBar
和可切换页面的控件。
在Android
中可以看成是ViewPager
和TabLayout
的结合。
实际效果的话,就下面这样了。
官方的动图
你可以选择直接上官方Github了解怎么使用,或者继续往下看我装逼。
npm install react-native-scrollable-tab-view --save
用tabLabel
指定Tab
名称
render() {
return (
<ScrollableTabView>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
效果:
(怎么感觉比Android里面简单多了~~)
使用goToPage
切换页面
render() {
return (
<ScrollableTabView
ref={(tabView) => {
this.tabView = tabView;
}}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Button tabLabel='Tab 3' onPress={() => this.tabView.goToPage(0)}
title='GO to Tab 1'/>
</ScrollableTabView>
);
}
this.tabView.goToPage(0)
:跳转到第0页 (页面:0、1、2...)
TabBar
的样式,可以使用官方提供的DefaultTabBar
(默认)、ScrollableTabBar
,也可以自定义。render() {
return (
<ScrollableTabView
renderTabBar={() => <DefaultTabBar/>}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
DefaultTabBar
:自动分配水平方向的空间,空间不够时每个Tab会自动换行。ScrollableTabBar
:可以超过屏幕范围,滚动可以显示。
当然,我们还可以对他的样式进行调整。
render() {
return (
<ScrollableTabView
renderTabBar={() =>
<ScrollableTabBar style={{height: 40, borderWidth: 0, elevation: 2}}
tabStyle={{height: 40}}/>}>
...
</ScrollableTabView>
);
}
borderWidth
:设置边框(感觉没什么用)
elevation
:层级效果(阴影)
tabStyle
:每个小Tab
的Style
(修改style-height
后,不改变tabStyle-height
会导致TabBar
内容不居中)
TabBar
的位置。top
(default)、bottom
、overlayTop
(顶部、悬浮在内容视图之上)、overlayBottom
(底部、悬浮在内容视图之上)render() {
return (
<ScrollableTabView
tabBarPosition='top'>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
效果的话你一个个去试吧~~
Object
类型的参数,包含两个key
:i
(当前选中页面的下标)、ref
(被选中的Tab
对象)render() {
return (
<ScrollableTabView
onChangeTab={(obj) => {
console.log('current index : ' + obj.i)
}}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
render() {
return (
<ScrollableTabView
onScroll={(position) => {
console.log('position : ' + position)
}}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
从page0滑动到page1时打印的结果:
page0->page1
false
。设置成true
后,只能通过点击Tab
来切换页面。render() {
return (
<ScrollableTabView
locked={false}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
render() {
return (
<ScrollableTabView
initialPage={1}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
TabBar
指示器的样式 render() {
return (
<ScrollableTabView
tabBarUnderlineStyle={{backgroundColor:'#000000', height:1}}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
TabBar
背景色render() {
return (
<ScrollableTabView
tabBarBackgroundColor='#FFFFFF'>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
Tab
选中时的文字颜色render() {
return (
<ScrollableTabView
tabBarActiveTextColor='#000000'>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
Tab
未选中时的文字颜色render() {
return (
<ScrollableTabView
tabBarInactiveTextColor='#666666'>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
TabBar
文字样式tabBarTextStyle={fontFamily: 'Roboto', fontSize: 15}
怎么用????
render() {
return (
<ScrollableTabView
scrollWithoutAnimation={true}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
render() {
return (
<ScrollableTabView
prerenderingSiblingsNumber={3}>
<Text tabLabel='Tab 1'>Tab 1</Text>
<Text tabLabel='Tab 2'>Tab 2</Text>
<Text tabLabel='Tab 3'>Tab 3</Text>
</ScrollableTabView>
);
}
在完全显示页面前(滑动的过程中),默认是不渲染View的。只有完全切换到当前页面时,才开始渲染选中的View。 例:第一次page0->page1,当page1未完全显示时。page1还未开始渲染,是个空页面。
react-native-scrollable-tab-view [React Native]react-native-scrollable-tab-view(入门篇)
以上有错误之处,感谢指出
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有