在之前项目中,在进行返回键退出应用时,应用的代码如下:
componentWillMount()
{
if (Platform.OS === 'android')
{
BackHandler.addEventListener('hardwareBackPress', this.onBackAndroid);
}
}
componentWillUnmount()
{
if (Platform.OS === 'android') {
BackHandler.removeEventListener('hardwareBackPress', this.onBackAndroid);
}
}
onBackAndroid = () => {
const navigator = this.refs.navigator;
const { navigator } = this.props;
const routers = navigator.getCurrentRoutes();
console.log('当前路由长度:'+routers.length);
if (routers.length > 1) {
navigator.pop();
return true;//接管默认行为
}
return false;//默认行为
};
可是在后面的项目中,用的是 react-navigation 这个组件,这个组件中没有getCurrentRoutes()这个方法了,所以没办法用上面的代码了。如果我们现在依旧想要达到在主页连续进行两次返回键,则退出APP怎么办呢?如下代码:
componentWillMount() {
if (Platform.OS === 'android') {
BackHandler.addEventListener('hardwareBackPress', this.onBackAndroid);
}
}
componentWillUnmount(){
if (Platform.OS === 'android') {
BackHandler.removeEventListener('hardwareBackPress', this.onBackAndroid);
}
};
上面这一部分依旧不变,
onBackAndroid = () => {
//禁用返回键
if(this.props.navigation.isFocused()){//判断 该页面是否处于聚焦状态
if (this.lastBackPressed && this.lastBackPressed + 2000 >= Date.now()) {
BackHandler.exitApp();//直接退出APP
}else{
this.lastBackPressed = Date.now();
ToastAndroid.show('再按一次退出应用', 1000);//提示
return true;
}
}
}
这里,我们用到的是this.props.navigation.isFocused() 的isFocused()这个方法来判断,改页面是否处于聚焦状态,如果是,则进行连续点击两次返回键,退出APP。如果不是,则执行返回操作。