vue.js - vue-router 嵌套路由和多个路由器视图没有内容
问题描述
我有一个 vue 应用程序,其中有两个路由器视图,用于 App.vue 文件中的布局和内容:
<router-view name="layout">
<div>
<router-view name="content" />
</div>
</router-view>
然后使用布局组件和内容组件配置路由:
{
path: "/",
components: {
layout: Layout,
content: ExampleContent
}
}
这一切正常。但是,我现在正在尝试使用嵌套路由添加一个页面,以在不同的 vuetify 选项卡中呈现不同的组件。
新路线:
{
path: "/tabs",
components: {
layout: Layout,
content: Tabs
},
children: [
{
path: "one",
component: TabOne
},
{
path: "two",
component: TabTwo
}
]
}
选项卡.vue
<template>
<div>
<h1>Tabs</h1>
<v-tabs>
<v-tab v-for="tab in tabs" :key="tab.id" :to="tab.route" exact>{{
tab.name
}}</v-tab>
</v-tabs>
<router-view></router-view>
</div>
</template>
<script>
export default {
data() {
return {
tabs: [
{ id: 1, name: "Tab One", route: `/tabs/one` },
{ id: 2, name: "Tab Two", route: `/tabs/two` },
],
};
},
};
</script>
选项卡正确呈现,并转到正确的路线,但没有任何内容。我尝试使用路由器链接而不是 v-tab 没有成功,所以我认为问题与路由器设置有关,与选项卡无关。
如果我将“内容”路由器视图移到“布局”路由器视图之外,则选项卡特定内容会正确显示,所以看起来路由/路由器视图的嵌套有些东西不起作用,但到目前为止,我一直无法弄清楚是什么。
在此处显示问题的代码沙箱
解决方案
我无法找到直接解决此问题的方法,但我确实找到了解决方法。我没有在路由中指定布局组件,而是在 App.vue 中添加了逻辑来呈现正确的组件。
应用程序.vue
<component :is="layoutComponent" />
computed: {
layoutComponent: function () {
return Layout;
},
},
然后从路由定义中删除布局的配置。布局中只有一个路由器视图组件,孩子们可以正常工作。
在此处更新代码沙箱
推荐阅读
- linux - 使 idevicerestore 不起作用(事件->类型 == IRECV_DEVICE_ADD)
- c++11 - 可变元组实现
- python - Ide 的差异(Python 中的内存优化)
- java - tinylog2 不创建日志文件
- excel - 使用excel VBA查找包含数值的单元格的列号
- html5-canvas - 以 60 fps 从画布捕获帧
- javascript - 如何使用 useEffect 在 React 中创建粘性标题
- wpf - 不透明度遮罩wpf中的图像
- angular - 在特征内选择数据的ngrx/entity问题
- c++ - 从 std::map 获取值,这是一个用户定义的类对象,导致无效读取