vue3容器布局和導(dǎo)航路由實(shí)現(xiàn)示例
容器布局
將App.vue中的HelloWorld相關(guān)內(nèi)容注釋或刪除掉,然后將element-plus提供的布局復(fù)制過(guò)來(lái)放在App.vue中
該布局為左側(cè)菜單欄,右邊內(nèi)容區(qū),右上為頂部,典型的管理后臺(tái)風(fēng)格
<template>
<!-- <img alt="Vue logo" src="./assets/logo.png"> -->
<div class="common-layout">
<el-container>
<el-aside width="200px">
<Menu></Menu>
</el-aside>
<el-container>
<el-header height="20px">Header</el-header>
<el-main>
<router-view></router-view>
</el-main>
</el-container>
</el-container>
</div>
<!--
<div>
<p>
<router-link to="/home">Go to Home</router-link>
<router-link to="/about">Go to about</router-link>
<router-view></router-view>
</p>
</div>
<HelloWorld msg="Welcome to Your Vue.js App"/> -->
</template>
<script>
// import HelloWorld from './components/HelloWorld.vue'
import Menu from './components/Menu.vue'
export default {
name: 'App',
components: {
// HelloWorld
Menu
}
}
</script>
上述代碼中有Menu.vue組件,需要新建,稍后再添加內(nèi)容
路由定義
在src目錄新建routes.js文件,將路由列表寫(xiě)入,方便其它組件使用
const routes = [
{ path: "/home", name: 'home', label: '首頁(yè)', component: () => import('./components/home.vue'), },
{ path: "/about", name: 'about', label: '關(guān)于', component: () => import('./components/about.vue'), },
]
export default routes
內(nèi)容沒(méi)有什么變化,就是將router.js 中的routes抽出來(lái),單獨(dú)寫(xiě)一個(gè)文件
router.js引入并使用routes
import { createRouter, createWebHashHistory } from 'vue-router'
import routes from './routes'
const router = createRouter({
history: createWebHashHistory(),
routes: routes,
})
export default router
左側(cè)菜單
在components目錄中新建Menu.vue頁(yè)面,然后將element-plus中菜單組件中Side bar 復(fù)制過(guò)來(lái)。
<template>
<el-row class="tac">
<el-col :span="24">
<h5 class="mb-2">Default colors</h5>
<el-menu default-active="2" class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose">
<el-sub-menu index="1">
<template #title>
<el-icon>
<location />
</el-icon>
<span>Navigator One</span>
</template>
<router-link v-for="(item, index) in routes" :to="{ name: item.name }" :key="item.name">
<el-menu-item :index="index">
<span v-text="item.label"></span>
</el-menu-item>
</router-link>
</el-sub-menu>
<el-menu-item index="2">
<el-icon>
<icon-menu />
</el-icon>
<span>Navigator Two</span>
</el-menu-item>
<el-menu-item index="3" disabled>
<el-icon>
<document />
</el-icon>
<span>Navigator Three</span>
</el-menu-item>
<el-menu-item index="4">
<el-icon>
<setting />
</el-icon>
<span>Navigator Four</span>
</el-menu-item>
</el-menu>
</el-col>
</el-row>
</template>
<script>
import {
Document,
Menu as IconMenu,
Location,
Setting,
} from '@element-plus/icons-vue'
import routes from '../routes'
export default {
name: 'Menu',
components: { Document, IconMenu,Location, Setting },
data() {
return {
routes: routes,
}
},
methods: {
handleOpen() {
console.log("111")
},
handleClose() {
console.log("222")
},
}
}
</script>
@element-plus/icons-vue 此包需要安裝(npm install @element-plus/icons-vue)
element-plus官網(wǎng)中的例子都是ts+setup語(yǔ)法寫(xiě)的,這里我們改成js+響應(yīng)式語(yǔ)法
列寬改成:span="24"或更大值,列寬太小會(huì)發(fā)現(xiàn)灰線在字體中間
引入定義的路由列表routes.js,將內(nèi)容循環(huán)到 router-link中
運(yùn)行效果如下

結(jié)語(yǔ):
后續(xù)加路由直接加到routes.js既可,簡(jiǎn)單的左側(cè)菜單,右側(cè)內(nèi)容區(qū)就實(shí)現(xiàn)了,以上就是vue3容器布局和導(dǎo)航路由實(shí)現(xiàn)示例的詳細(xì)內(nèi)容,更多關(guān)于vue3容器布局導(dǎo)航路由的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- vue3配置permission.js和router、pinia實(shí)現(xiàn)路由攔截的簡(jiǎn)單步驟
- Vue3中關(guān)于路由規(guī)則的props配置方式
- vue3 vite pinia配置動(dòng)態(tài)路由、解決刷新頁(yè)面路由消失的問(wèn)題
- vue3配置router路由并實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)功能
- vue3路由配置以及路由跳轉(zhuǎn)傳參詳解
- Vue3路由配置createRouter、createWebHistory、useRouter和useRoute詳解
- vite?vue3下配置history模式路由的步驟記錄
- Vue3?路由配置與導(dǎo)航實(shí)戰(zhàn)教程
相關(guān)文章
vue實(shí)現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例
這篇文章主要介紹了vue實(shí)現(xiàn)點(diǎn)擊出現(xiàn)操作彈出框的示例,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下2020-11-11
vue前端重構(gòu)computed及watch組件通信等實(shí)用技巧整理
這篇文章主要為大家介紹了vue前端重構(gòu)computed及watch組件通信等實(shí)用技巧整理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
解決vue2中使用elementUi打包報(bào)錯(cuò)的問(wèn)題
這篇文章主要介紹了解決vue2中使用elementUi打包報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
vue2.0實(shí)現(xiàn)檢測(cè)無(wú)用的代碼并刪除
這篇文章主要介紹了vue2.0實(shí)現(xiàn)檢測(cè)無(wú)用的代碼并刪除方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
vue router 跳轉(zhuǎn)后回到頂部的實(shí)例
今天小編就為大家分享一篇vue router 跳轉(zhuǎn)后回到頂部的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
Nginx同一端口部署多個(gè)前后端分離的vue項(xiàng)目完整步驟
最近做項(xiàng)目結(jié)構(gòu)優(yōu)化,前端項(xiàng)目都是部署在nginx上,想實(shí)現(xiàn)同一個(gè)端口可以訪問(wèn)多個(gè)前端項(xiàng)目,所以就有了本文,這篇文章主要給大家介紹了關(guān)于Nginx同一端口部署多個(gè)前后端分離的vue項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2023-10-10
vue獲取v-for異步數(shù)據(jù)dom的解決問(wèn)題
這篇文章主要介紹了vue獲取v-for異步數(shù)據(jù)dom的解決問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03

