开发者问题收集

使用 StackNavigator 将 React Native 从子组件移到父组件

2018-06-26
71

如何从子组件导航到父组件?

YoutubeVideo.js

        <YouTube
            videoId={this.state.VideoId}  
            play={false}             
            loop={false}            
            apiKey={apikey}
            onReady={e => this.setState({ isReady: true })}
            onChangeState={e => this.setState({ status: e.state })}
            onChangeQuality={e => this.setState({ quality: e.quality })}
            onError={e => this.setState({ error: e.error })}
            style={{ alignSelf: 'stretch', height: 250 }}
        />
        <Related videoId={this.state.VideoId}    />
      </View>

RelatedComponent.js

   <View>
   <ScrollView>
     <RkCard rkType='shadowed' >
        {this.state.data.map((item, i) => 
        <TouchableHighlight 
          key={item.id.videoId} 
      onPress={() => props.navigate('YoutubeVideo', {youtubeId:item.id.videoId})}>
          <View rkCardContent>
            <Image  rkCardImg
              source={{uri: item.snippet.thumbnails.medium.url}} 
              style={styles.image}/>
            <View style={styles.vidItems}>
              <Text style={styles.vidText}>{item.snippet.title}</Text>
              <Icon name='more-vert' size={20} color='#555'/> 
            </View>
          </View>
        </TouchableHighlight>
        )}
      </RkCard>
    </ScrollView>
  </View>

我想从相关视频发送新的 Youtube ID,但它是同一页面。

1个回答

您无需再次导航到 YoutubeVideo。您可以通过回调将 videoID 传递给父级,如下所示:

RelatedComponent.js

...
<TouchableHighlight  
    onPress={() => {this.props.onVideoClick(item.id.videoId)} }
>
...

YoutubeVideo.js

...
<Related 
     videoId={this.state.VideoId}    
     onVideoClick={(videoID) => { this.setState({ VideoId: 'videoID' }) }}
/>
...

您可以通过这种方式将数据发送给父级。希望这对您有所帮助

Ali SabziNezhad
2018-06-26