2016-05-06 21 views
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; 

結果がこれです:

schermata 2016-05-06 alle 15 35 59

WそれはNavBarを複製するのですか?助言がありますか?

答えて

0

ここにあなたのコード:

---> state.children.map(el => { 
      return (
       <DefaultRenderer navigationState={el} key={el.key} {...el} tabLabel={el.title} /> 
      ); 
      }) 

state.childrenは、おそらくあなたのナビゲーションバーを含んでいます。返品の代わりにconsole.log(el);で確認してみてください。またはブロックの前に `console.log(state.children)。あなたのprops.tabが何であるか、あなたの上位コンポーネントが何であるかを知らなくても、問題が何であるかを言うのは難しいです。

関連する問題