0
反応ネイティブスクロールタブビューを反応ネイティブルータフラックスと併用したいので、このScrollableTabViewを作成しました:反応ネイティブルータフラックスでスクロール可能なタブビューを使用する方法
import React, {
Component,
} from 'react';
import ScrollableTabView from 'react-native-scrollable-tab-view';
import { DefaultRenderer } from 'react-native-router-flux';
import TabBar from './TabBar';
class ScrollableTab extends Component {
render(){
const state = this.props.navigationState;
return (
<ScrollableTabView renderTabBar={() => <TabBar />} >
{
state.children.map(el => {
return (
<DefaultRenderer navigationState={el} key={el.key} {...el} tabLabel={el.title} />
);
})
}
</ScrollableTabView>
);
}
}
export default ScrollableTab;
と、このTabBarの:
import React from 'react';
import {
StyleSheet,
Text,
View,
TouchableOpacity,
Animated,
Component
} from 'react-native';
const styles = StyleSheet.create({
tab: {
flex: 1,
alignItems: 'center',
justifyContent: 'center',
paddingBottom: 10,
},
tabs: {
marginBottom: 70,
top: 64,
height: 45,
flexDirection: 'row',
paddingTop: 5,
borderWidth: 1,
borderTopWidth: 0,
borderLeftWidth: 0,
borderRightWidth: 0,
borderBottomColor: 'rgba(0,0,0,0.05)',
},
tabUnderlineStyle: {
position: 'absolute',
height: 3,
backgroundColor: '#3b5998',
bottom: 0,
},
});
const propTypes = {
goToPage: React.PropTypes.func,
activeTab: React.PropTypes.number,
tabs: React.PropTypes.array,
};
class TabBar extends Component {
render() {
return (
<View style={styles.tabs} >
{this.props.tabs.map((tab, i) => {
return (
<TouchableOpacity style={styles.tab} key={tab} onPress={() => this.props.goToPage(i)} >
<Text>
{tab}
</Text>
</TouchableOpacity>
);
})}
</View>
);
}
}
TabBar.propTypes = propTypes;
export default TabBar;
結果がこれです:
WそれはNavBarを複製するのですか?助言がありますか?