作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用createMaterialTopTabNavigator
来自 react 导航,其中我有两个单独的屏幕 UpdatesStack
和ShopsStack
我想从这些屏幕导航到其他屏幕,所以我写了 <Toptab navigation={this.props.navigation} />
它向我显示以下红屏错误。
如果我写成 <Toptab />
然后没有错误,但我无法导航。
那么我该如何解决这个问题并能够导航。
代码
class Parenthome extends Component {
render() {
const { navigate } = this.props.navigation;
return (
<View style={styles.container}>
<ToolbarAndroid
style={styles.toolbar}
title="Toolbar"
titleColor="#ff6600"
/>
<Toptab navigation={this.props.navigation} />
</View>
);
}
}
const UpdatesStack = createStackNavigator(
{
Updates: { screen: Home }
},
{
initialRouteName: "Updates"
}
);
const ShopsStack = createStackNavigator(
{
Shops: { screen: Conshop }
},
{
initialRouteName: "Shops"
}
);
const Toptab = createMaterialTopTabNavigator({
Updatestab: { screen: UpdatesStack },
Shopstab: { screen: ShopsStack }
});
export default Parenthome;
最佳答案
我知道现在已经晚了,但只是为了回答那些从搜索引擎中偶然发现此问题的人:
为什么不导出默认的 TopTab 本身。在您的用例中,似乎没有必要将 TopTab 与 ParentTheme 组件一起包装。您可以设置 TopTab 导航器本身的样式并像任何其他组件一样渲染它。
如果您必须包装 TopTab,除了导航属性之外,您还需要从 TopTab 访问路由器。这样它们都引用同一个路由器。简单来说,在ParentTheme中添加:
静态路由器= TopTab.router;
查看自定义导航器以获取更多信息。 https://reactnavigation.org/docs/en/custom-navigators.html
关于reactjs - 类型错误 : No "routes" found in navigation state,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51675083/
我是一名优秀的程序员,十分优秀!