我有一个问题,我肯定有一个简单的解决方案,但我是React和React Native的新手,所以我不确定我缺少什么. 我的应用程序根目录有一个TabBarIOS组件,有两个选项卡:TabA和TabB. TabB订阅了TabA创建
我的应用程序根目录有一个TabBarIOS组件,有两个选项卡:TabA和TabB. TabB订阅了TabA创建的Flux商店(我正在使用alt)的事件. TabA基本上将TabB播放的项目排入队列.这部分代码很好,并按预期工作.
问题是TabA是默认选项卡,因此用户可以使用TabA作为排队项目,但由于未触摸/单击TabB,因此尚未创建TabB组件,因此尚未注册其侦听器.只有在按下TabB时才会创建并正确接收事件.
那么如何在呈现TabBarIOS组件时确保创建TabB组件?我是否需要一些hacky,比如在初始加载时将活动选项卡设置为TabB并在用户执行任何操作之前将其翻转回TabA?
是的,如果你没有使用Navigator组件,你需要做一些hacky.如果您正在使用Navigatory,可以使用initialRouteStackprop指定一组最初安装的路由.然而,这需要您按照我认为的应用程序的方式进行修改.如果不使用Navigator,你确实必须按照你的建议做一些hacky.我已经基于RN的TabBar示例设置了一个工作示例here.
下面你会找到这个例子的代码,检查console.log(它们似乎不适用于rnplay),看看在打开应用程序时是否安装了这些组件.
示例代码
var React = require('react-native'); var { AppRegistry, Component, Image, StyleSheet, TabBarIOS, Text, View } = React; import _ from 'lodash'; var base64Icon = ''; class StackOverflowApp extends Component { constructor(props) { super(props); this.state = { selectedTab: 'blueTab', notifCount: 0, presses: 0 }; } _renderContent = (color, pageText, num) => { return ( <View style={[styles.tabContent, {backgroundColor: color}]}> <Text style={styles.tabText}>{pageText}</Text> <Text style={styles.tabText}>{num} re-renders of the {pageText}</Text> </View> ); }; componentWillMount() { this.setState({selectedTab: 'redTab'}); } componentDidMount() { this.setState({selectedTab: 'blueTab'}); } render () { return ( <View style={{flex: 1}}> <TabBarIOS tintColor="white" barTintColor="darkslateblue"> <TabBarIOS.Item title="Blue Tab" icon={{uri: base64Icon, scale: 3}} selected={this.state.selectedTab === 'blueTab'} onPress={() => { this.setState({ selectedTab: 'blueTab', }); }}> <Page1 /> </TabBarIOS.Item> <TabBarIOS.Item systemIcon="history" badge={this.state.notifCount > 0 ? this.state.notifCount : undefined} selected={this.state.selectedTab === 'redTab'} onPress={() => { this.setState({ selectedTab: 'redTab' }); }}> <Page2 /> </TabBarIOS.Item> </TabBarIOS> </View> ); }; } class Page1 extends Component { static route() { return { component: Page1 } }; constructor(props) { super(props); } componentWillMount() { console.log('page 1 mount'); } componentWillUnmount() { console.log('page 1 unmount'); } render() { return ( <View style={styles.tabContent}> <Text style={styles.tabText}>Page 1</Text> </View> ); } } class Page2 extends Component { static route() { return { component: Page2 } }; constructor(props) { super(props); } componentWillMount() { console.log('page 2 mount'); } componentWillUnmount() { console.log('page 2 unmount'); } render() { return ( <View style={styles.tabContent}> <Text style={styles.tabText}>Page 2</Text> </View> ); } } const styles = StyleSheet.create({ tabContent: { flex: 1, backgroundColor: 'green', alignItems: 'center', }, tabText: { color: 'white', margin: 50, }, }); AppRegistry.registerComponent('StackOverflowApp', () => StackOverflowApp);