react-native-router-flux backAndroidHandler 不工作
react-native-router-flux backAndroidHandler not working
我正在开发一个反应原生的移动应用程序,我曾在其中使用过 react-native-router-flux
我有一个场景如下
1- Screen1
2- Screen2
3- Screen3
4- Screen4
当我在屏幕 4 上按 android 后退按钮时,它会转到屏幕 3,然后是 2,然后是 1
但是当我在 screen1 上按下 android 后退按钮时,它应该退出应用程序,但它不起作用
这是我的路由器堆栈
<Router navigationBarStyle={styles.navBar} titleStyle={styles.navTitle} navBarTintColor={'white'} navBarButtonImageColor={'white'} tintColor={'white'} sceneStyle={styles.routerScene} >
<Stack key="root">
<Scene
key="Screen1"
component={Screen1}
animation="fade"
hideNavBar={true}
initial={true}
type='replace'
/>
<Scene
key="Screen2"
component={Screen2}
animation="fade"
hideNavBar={true}
type='replace'
/>
<Scene
key="Screen3"
component={Screen3}
title="Enrollment"
animation="slide"
hideNavBar={false}
type='replace'
/>
<Scene
key="Screen4"
component={Screen4}
title="Enrollment"
animation="slide"
hideNavBar={false}
type='replace'
/>
我也试过使用下面的代码
componentWillMount(){
BackHandler.addEventListener('hardwareBackPress', this.onBackPress.bind(this));
}
componentWillUnmount(){
BackHandler.removeEventListener('hardwareBackPress', this.onBackPress.bind(this));
}
onBackPress() {
if (backButtonPressedOnceToExit) {
BackAndroid.exitApp();
} else {
if (Actions.currentScene !== 'Home') {
Actions.pop();
return true;
} else {
backButtonPressedOnceToExit = true;
ToastAndroid.show("Press Back Button again to exit",ToastAndroid.SHORT);
//setting timeout is optional
setTimeout( () => { backButtonPressedOnceToExit = false }, 2000);
return true;
}
}
}
当我尝试调试它时,我的调试器没有进入函数内部。
请让我知道我做错了什么。
使用 Router
组件的 backAndroidHandler
属性。
<Router navigationBarStyle={styles.navBar} titleStyle={styles.navTitle} navBarTintColor={'white'} navBarButtonImageColor={'white'} tintColor={'white'} sceneStyle={styles.routerScene} backAndroidHandler={this.onBackPress}>
并且在 onBackPress
中,您提到了错误的屏幕。 Home
不在您的路由器堆栈中。做到Screen1
。在第一个 if 条件中也是 'return true`。
我正在开发一个反应原生的移动应用程序,我曾在其中使用过 react-native-router-flux
我有一个场景如下
1- Screen1
2- Screen2
3- Screen3
4- Screen4
当我在屏幕 4 上按 android 后退按钮时,它会转到屏幕 3,然后是 2,然后是 1 但是当我在 screen1 上按下 android 后退按钮时,它应该退出应用程序,但它不起作用
这是我的路由器堆栈
<Router navigationBarStyle={styles.navBar} titleStyle={styles.navTitle} navBarTintColor={'white'} navBarButtonImageColor={'white'} tintColor={'white'} sceneStyle={styles.routerScene} >
<Stack key="root">
<Scene
key="Screen1"
component={Screen1}
animation="fade"
hideNavBar={true}
initial={true}
type='replace'
/>
<Scene
key="Screen2"
component={Screen2}
animation="fade"
hideNavBar={true}
type='replace'
/>
<Scene
key="Screen3"
component={Screen3}
title="Enrollment"
animation="slide"
hideNavBar={false}
type='replace'
/>
<Scene
key="Screen4"
component={Screen4}
title="Enrollment"
animation="slide"
hideNavBar={false}
type='replace'
/>
我也试过使用下面的代码
componentWillMount(){
BackHandler.addEventListener('hardwareBackPress', this.onBackPress.bind(this));
}
componentWillUnmount(){
BackHandler.removeEventListener('hardwareBackPress', this.onBackPress.bind(this));
}
onBackPress() {
if (backButtonPressedOnceToExit) {
BackAndroid.exitApp();
} else {
if (Actions.currentScene !== 'Home') {
Actions.pop();
return true;
} else {
backButtonPressedOnceToExit = true;
ToastAndroid.show("Press Back Button again to exit",ToastAndroid.SHORT);
//setting timeout is optional
setTimeout( () => { backButtonPressedOnceToExit = false }, 2000);
return true;
}
}
}
当我尝试调试它时,我的调试器没有进入函数内部。 请让我知道我做错了什么。
使用 Router
组件的 backAndroidHandler
属性。
<Router navigationBarStyle={styles.navBar} titleStyle={styles.navTitle} navBarTintColor={'white'} navBarButtonImageColor={'white'} tintColor={'white'} sceneStyle={styles.routerScene} backAndroidHandler={this.onBackPress}>
并且在 onBackPress
中,您提到了错误的屏幕。 Home
不在您的路由器堆栈中。做到Screen1
。在第一个 if 条件中也是 'return true`。