vue-router命名视图+路由嵌套
有这样一个需求,页面分为左右两个区域,两个区域的内容可能会各自变化,如果实现打开页面左右区域均有内容显示,且支持单独变化
*分析:
左右两个要同时显示,自然想到用使用命名视图,在compents中将多个组件放在一起展示,但是左右两侧的router-view中所放的内容是会变化的,这该如何解决呢?在单个router-view的时候,切换router-view显示的内容,切换path即可,那在多个router-view的时候,能否还能继续使用切换path的方式来改变显示的内容呢?沿着这个思路,还真把功能实现, 只是实现方式感觉很笨拙。
router
const routes = [ { path: "/", // MainPage用于承放页面左右两区域(用两个命名视图来占位:left-container、right-container) component: MainPage, children: [ { path: "/", redirect: "/content" }, { path: "content", // components让左右内容组件同时显示 components: { "left-container": LeftContainer, "right-container": RightContainer, }, // 子路由将左右两侧的组件组合起来显示 children: [ { path: "/content", redirect: "/content/welcome_and_camera" }, { path: "welcome_and_camera", // 各自占位 components: { "left-content": Welcome, "right-content": CameraVideo, }, }, { path: "facereco_and_camera", // 各自占位 components: { "left-content": FaceRecoResult, "right-content": CameraVideo, }, }, { path: "welcome_andschool", // 各自占位 components: { "left-content": Welcome, "right-content": School, }, }, ], }, ], },
MainPage.vue
<template> <div id="container"> <div id="left-panel"> <router-view name="left-container"></router-view> </div> <div id="right-panel"> <router-view name="right-container"></router-view> </div> </div> </template>
LeftContainer.vue
<template> <div> <h1>left</h1> <router-view name="left-content"></router-view> </div> </template>
RightContainer
<template> <div> <h1>right</h1> <router-view name="right-content"></router-view> </div> </template>
效果:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
2018-06-20 XAML绑定到资源文件字符串时失败
2018-06-20 VS2015 将*.xaml.cs文件包裹在*.xaml文件下