2016-08-12 12 views
4

私は反応ネイティブが新版です。私は私のアプリに2ページあります。戻るボタンを押すと前のページが開きますが、戻るボタンを押すとアプリが閉じるようになります。この問題を解決するために何ができるのですか?反応ネイティブを使用中にアンドロイドのボタンを押したときに閉じるとアプリが終了する

私のコードは次のとおりです。あなたが反応ネイティブのBackAndroid APIを使用する必要が

'use strict'; 

import React, { Component } from 'react'; 
import { 
    AppRegistry, 
    StyleSheet, 
    Text, 
    View, 
    Navigator, 
    TextInput, 
    TouchableHighlight 
} from 'react-native'; 
import ToolbarAndroid from 'ToolbarAndroid'; 
import ActionButton from 'react-native-action-button'; 
import backAndroid from 'react-native-back-android'; 
import {hardwareBackPress} from 'react-native-back-android'; 

class AwesomeProject extends Component { 
    renderScene(route, navigator) { 
    if(route.name == 'HomePage') { 
     return <HomePage navigator={navigator} {...route.passProps} /> 
    } 
    if(route.name == 'FormBuilderPage') { 
     return <FormBuilderPage navigator={navigator} {...route.passProps}  /> 
    } 
    } 

    render() { 
    return (
     <Navigator 
     style={{ flex:1 }} 
     initialRoute={{ name: 'HomePage' }} 
     renderScene={ this.renderScene } /> 
    ) 
    } 
} 
class BackButtonEvent extends React.Component{ 
    handleHardwareBackPress(){ 
    if(this.sate.isOpen()){ 
     this.handleClose(); 
     return true; 
    } 
    } 
} 
var HomePage = React.createClass({ 
    _navigate(name) { 
    this.props.navigator.push({ 
     name: 'FormBuilderPage', 
     passProps: { 
     name: name 
    } 
    }) 
    }, 
    render() {  
    return (
     <View style={styles.container}>   
     <ToolbarAndroid style = {styles.toolbar}> 
      <Text style = {styles.titleText}> Data Collector </Text> 
     </ToolbarAndroid> 
     <ActionButton 
      source = {require('./icon_container/ic_plus_circle_add_new_form.png')} 
      onPress = {this._navigate} 
      > 
     </ActionButton> 
     </View> 
    ) 
    } 
}) 

var FormBuilderPage = React.createClass({ 

    render() {  
    return (
     <View style={styles.container}> 
     <ToolbarAndroid style = {styles.toolbar}> 
      <TextInput placeholder = "Text here"/> 
     </ToolbarAndroid> 
     </View> 
    ) 
    } 
}) 

var styles = StyleSheet.create({ 
    container: { 
    flex: 1, 
    backgroundColor: '#F5FCFF', 
    }, 
    toolbar: { 
    height: 56, 
    backgroundColor: '#3F51B5' 
    }, 
    titleText: { 
    color: '#fff', 
    } 
}); 

AppRegistry.registerComponent('AwesomeProject',() => AwesomeProject); 
+0

backAndroid関数でコンポーネントをラップしていると思います。 – while1

+0

だから、それはどこですか? –

+0

このhttp://facebook.github.io/react-native/releases/0.29/docs/backandroid.htmlを使用していますか? – Cherniv

答えて

2

。これは私のサンプルプロジェクトのスニペットです。

BackAndroid.addEventListener('hardwareBackPress',() => { 

    var flag = false; 

    if(_route.name==="newbooking"){ 
     Alert.alert(
      "Confirmation", 
      "Are you sure you want to cancel?", 
      [ 
       {text: 'No', onPress:() => console.log('OK Pressed!')}, 
       {text: 'Yes', onPress:() => {_navigator.pop();}} 
      ] 
     ); 
     return true; 
    } 
    else{ 
     flag = true; 
    } 
    if (_navigator.getCurrentRoutes().length === 1 ) { 
     return false; 
    } 
    if(flag){ 

     _navigator.pop(); 
     return true; 
    } 

}); 

これは私がどのように実装したか見ることができますhere

関連する問題