Vue?Router組合布局用法詳解
常用的布局
我們首先看一個我們常用的布局,左右布局。
app 頁面
我們通常寫一個這樣的布局,思路是這樣的:
- 我們首先要寫三個組件
meun.vue
,header.vue
,collect.vue
- 在app添加引入單個組件
# app.vue <template> <div class="contain flex p10 mt40 ml40"> <Menu class="menu width-200 flex-center mr10" /> <div class="flex1 flex-column"> <Header class="header mb10 p10 flex-center"></Header> <router-view class="view-main"></router-view> </div> </div> </template> <script setup> import Header from './views/home/header.vue'; import Menu from './views/home/menu.vue'; </script>
about 頁面
如果我們的about
頁面,像這樣的,沒有menu
或者header
我們可以根據(jù)路由判斷是否顯示menu
或者header
組件
<template> <div class="contain flex p10 mt40 ml40"> <Menu class="menu width-200 flex-center mr10" v-if="route.name !== 'about'" /> <div class="flex1 flex-column"> <Header class="header mb10 p10 flex-center"></Header> <router-view class="view-main"></router-view> </div> </div> </template> <script setup> import { useRoute } from 'vue-router'; import Header from './views/home/header.vue'; import Menu from './views/home/menu.vue'; const route = useRoute(); </script>
思考??
這是我們的常規(guī)操作,如果我們有些頁面不需要menu
或者header
頁面,我們都是要引入的,還有判斷是否顯示隱藏。
怎么才能不寫這么多判斷,又能提高性能的同時,還能實現(xiàn)我們的效果呢?
- 使用異步組件動態(tài)導(dǎo)入
defineAsyncComponent
, 有需要組件去官網(wǎng)看下 - 使用
vue router命名視圖
命名視圖
我們這里使用命令視圖, 來實現(xiàn)我們想要的效果
有時候想同時 (同級) 展示多個視圖,而不是嵌套展示,例如創(chuàng)建一個布局,有
sidebar
(側(cè)導(dǎo)航) 和main
(主內(nèi)容) 兩個視圖,這個時候命名視圖就派上用場了。你可以在界面中擁有多個單獨命名的視圖,而不是只有一個單獨的出口。如果router-view
沒有設(shè)置名字,那么默認為default
。
<router-view class="view left-sidebar" name="LeftSidebar"></router-view> <router-view class="view main-content"></router-view> <router-view class="view right-sidebar" name="RightSidebar"></router-view>
Router組合布局
項目目錄結(jié)構(gòu)
router-demo ├── src │ ├── App.vue │ ├── assets │ │ └── vue.svg │ ├── main.js │ ├── router │ │ └── index.js │ ├── store │ │ └── index.js │ ├── utils │ │ └── request.js │ └── views │ ├── about │ │ ├── api │ │ │ └── index.js │ │ ├── index.vue │ │ ├── router │ │ │ └── index.js │ │ └── store │ │ └── index.js │ ├── home │ │ ├── header.vue │ │ └── menu.vue │ └── main │ ├── api │ │ └── index.js │ ├── index.vue │ ├── router │ │ └── index.js │ └── store │ └── index.js └── vite.config.js
- 修改
app.vue
視圖顯示
注意看下??:添加了兩個router-view
命名視圖
<template> <div class="contain flex p10 mt40 ml40"> <router-view class="menu width-200 flex-center mr10" name="Menu" /> <div class="flex1 flex-column"> <router-view class="header mb10 p10 flex-center" name="Headers" /> <router-view class="view-main"></router-view> </div> </div> </template> <script setup> </script>
- 修改
main
文件夾中的route.js
這里 注意??:component
修改components
// mian/router/index.js export default [ { path: '/main', name: 'main', components: { default: () => import('../index.vue'), Headers: () => import('@/views/home/header.vue'), Menu: () => import('@/views/home/menu.vue'), }, }, ];
- 修改
about
文件夾的router.js
// about/router/index.js export default [ { path: '/about', name: 'about', components: { default: () => import('../index.vue'), Headers: () => import('@/views/home/header.vue'), }, }, ];
如果想顯示哪個視圖,就在相對應(yīng)的路由components
添加相應(yīng)的視圖組件,這樣是不是方便了許多。
結(jié)論
- 不用在
app.vue
添加判斷是否顯示隱藏header
和menu
組件 - 根據(jù)路由動態(tài)顯示布局樣式
這只是提示多一種新的布局方式,方便我們開發(fā),當然還是選擇合適自己的寫法。
以上就是Vue Router組合布局用法詳解的詳細內(nèi)容,更多關(guān)于Vue Router組合布局的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解gantt甘特圖可拖拽、編輯(vue、react都可用?highcharts)
去年我遇到了一個甘特圖的需求,做了很多工作,最終還是不完美,今天使用一個新包,給大家重新學(xué)習(xí)下vue?甘特圖gantt的相關(guān)知識,感興趣的朋友一起看看吧2021-11-11Vue+axios+WebApi+NPOI導(dǎo)出Excel文件實例方法
在本篇文章里小編給大家整理關(guān)于Vue+axios+WebApi+NPOI導(dǎo)出Excel文件的知識點以及實例代碼,需要的朋友們參考下。2019-06-06