假設你正在使用您的Navigator
文件index.android.js
應該是這樣的:
export default class Foo extends React.Component {
constructor(props) {
super(props);
this._navigator = null;
}
renderScene(route, navigator) {
if(!this._navigator){
this._navigator = navigator;
BackAndroid.addEventListener('hardwareBackPress',() => {
if (this._navigator && this._navigator.getCurrentRoutes().length > 1) {
this._navigator.pop();
return true;
}
return true;
});
}
return React.createElement(component, { ...this.props, ...route.passProps, route, navigator });
}
render() {
return (
<Navigator
initialRoute={...}
configureScene={...}
renderScene={(route, nav) => {return this.renderScene(route, nav)}}
/>
);
}
}
AppRegistry.registerComponent('Foo',() => Foo);
如果你不使用Navigator
IDK如何才能做到這一點,因爲hardwareBackPress
不知道堆棧上的任何位置。