我有一个Router
带有 2 个选项卡场景的设置:
- 选项卡 1:有 2 个可导航场景(静态屏幕);
- 屏幕 A:有一个按钮可以导航到屏幕 B;
- 屏幕B:只有一个文本;
- 选项卡 2:只有 1 个静态屏幕。
- 屏幕C:只有一个文本;
代码如下。
应用程序.js:
import React from 'react';
import { Router, Scene } from 'react-native-router-flux';
import Tab from '../tab';
import ScreenA from './a';
import ScreenB from './b';
import ScreenC from './c';
export default class App extends React.Component {
render(){
return (
<Router>
<Scene key="root">
<Scene key="tabbar" tabs={true}>
<Scene key="tab1" title="Tab 1" icon={Tab}>
<Scene key="a" title="Screen A" component={ScreenA} />
<Scene key="b" title="Screen B" component={ScreenB} />
</Scene>
<Scene key="tab2" title="Tab 2" icon={Tab}>
<Scene key="c" title="Screen C" component={ScreenC} />
</Scene>
</Scene>
</Scene>
</Router>
);
}
}
画面也很简单。
一个.js:
export default class ScreenA extends React.Component {
render(){
return (
<View>
<Text>This is Screen A</Text>
<TouchableHighlight onPress={() => Actions.b()}>
<Text>Go to Screen B</Text>
</TouchableHighlight>
</View>
);
}
}
b.js:
export default class ScreenB extends React.Component {
render(){
return (
<View>
<Text>This is Screen B</Text>
</View>
);
}
}
c.js:
export default class ScreenC extends React.Component {
render(){
return (
<View>
<Text>This is Screen C</Text>
</View>
);
}
}
用例:
- 应用程序呈现屏幕 A(在选项卡 1 中);
- 单击屏幕 A 中的按钮:应用程序导航到屏幕 B(仍在选项卡 1 中);
- 单击选项卡 2:应用程序导航到屏幕 C(在选项卡 2 中)。
- 单击选项卡 1:应用程序导航到屏幕 A(在选项卡 1 中)而不是屏幕 B,如预期的那样。
react-native-router-flux
当我们回到它们时,不会保留选项卡的历史堆栈。还是我在这里做错了什么?
软件包版本:
- 反应 v15.3.2
- 反应原生 v0.34.1
- react-native-router-flux v3.36.0