element-ui使用導(dǎo)航欄跳轉(zhuǎn)路由的用法詳解
最近初學(xué)vue,試著做一個小項目熟悉語法與思想,其中使用elemen-ui的導(dǎo)航欄做路由跳轉(zhuǎn)切換頁面。下面記錄一下學(xué)習(xí)過程
element-ui引入vue項目的用法參考element官網(wǎng)
首先復(fù)制官網(wǎng)的例子,在這基礎(chǔ)上再修改成我們想要的樣子。
<el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect"> <el-menu-item index="1">處理中心</el-menu-item> <el-submenu index="2"> <template slot="title">我的工作臺</template> <el-menu-item index="2-1">選項1</el-menu-item> <el-menu-item index="2-2">選項2</el-menu-item> <el-menu-item index="2-3">選項3</el-menu-item> <el-submenu index="2-4"> <template slot="title">選項4</template> <el-menu-item index="2-4-1">選項1</el-menu-item> <el-menu-item index="2-4-2">選項2</el-menu-item> <el-menu-item index="2-4-3">選項3</el-menu-item> </el-submenu> </el-submenu> <el-menu-item index="3" disabled>消息中心</el-menu-item> <el-menu-item index="4"><a rel="external nofollow" target="_blank">訂單管理</a></el-menu-item> </el-menu> <script> export default { data() { return { activeIndex: '1' }; }, methods: { handleSelect(key, keyPath) { console.log(key, keyPath); } } } </script>
屬性:
* default-active:表示當(dāng)前active的菜單項的編號
* index:類型為字符串,在每一個el-menu-item組件上都有一個編號,給default-active標(biāo)記
使用菜單欄進行路由跳轉(zhuǎn):
<el-menu :default-active="this.$router.path" router mode="horizontal"> <el-menu-item v-for="(item,i) in navList" :key="i" :index="item.name"> {{ item.navItem }} </el-menu-item> </el-menu>
數(shù)據(jù):
data() { return { navList:[ {name:'/findProject',navItem:'發(fā)現(xiàn)項目'}, {name:'/communityActivity',navItem:'社區(qū)動態(tài)'}, {name:'/publishProject',navItem:'發(fā)布項目'}, {name:'/personalCenter',navItem:'個人中心'}, {name:'/manageCenter',navItem:'管理員中心'}, ] } }
路由:
export default new Router({ routes: [{ path: '*', redirect: '/findProject' }, { path: '/findProject', name: 'findProject', component: findProject }, { path: '/communityActivity', name: 'communityActivity', component: communityActivity }, { path: '/publishProject', name: 'publishProject', component: publishProject }, { path: '/personalCenter', name: 'personalCenter', component: personalCenter }, { path: '/manageCenter', name: 'manageCenter', component: manageCenter }] })
使用菜單欄進行路由跳轉(zhuǎn)有幾個注意點:
1. 在el-menu加上router
2. index必須綁定路由的path,參考上面的例子,'/'不能少
3. default-active設(shè)為當(dāng)前路由(this.$router.path),這樣在路由變化的時候,對應(yīng)的menu-item才會高亮。
拓展知識:vue項目中的路由配置方法
公司的項目使用vue腳手架來搭建,是屬于后臺管理系統(tǒng)。功能頁比較多,就使用vue路由來進行跳轉(zhuǎn);
個人比較習(xí)慣上面這種方式放置路由文件,并且使用懶加載的模式來配置,如下:
import Vue from 'vue' import Router from 'vue-router' //import Login from '.././views/login.vue' //import NotFound from '.././views/404.vue' //import Home from '.././views/index.vue' Vue.use(Router) export default new Router({ mode: 'history',//去掉#號 routes: [ { path: '/login', name: 'Login', component: resolve => require(['../views/login.vue'],resolve) }, { path: '/404', name: 'NotFound', component: resolve => require(['../views/404.vue'],resolve) }, { path: '/', redirect: '/default' }, { path: '/', name: 'Home', component: resolve => require(['../views/index.vue'],resolve), meta: {title: '自述文件'}, children:[ { path: '/default', component: resolve => require(['../components/default.vue'],resolve), meta: {title: '系統(tǒng)首頁'} }, { path: '/set', component: resolve => require(['../components/set.vue'],resolve), meta: {title: '設(shè)置'} }, { path: '/user', component: resolve => require(['../components/user.vue'],resolve), meta: {title: '賬戶管理'} }, { path: '/member', component: resolve => require(['../components/memberList/memberList.vue'],resolve), meta: {title: '會員列表'} }, { path: '/baseCharts', component: resolve => require(['../components/charts/baseCharts.vue'],resolve), meta: {title: '會員分析'} } ] } ] })
在main.js中使用路由進行配置:
這樣就可以在需要的地方使用路由了。
以上這篇element-ui使用導(dǎo)航欄跳轉(zhuǎn)路由的用法詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值實例詳解
父組件通過屬性傳值給子組件,父組件修改數(shù)據(jù)后會刷新頁面并重新傳值給子組件,子組件可以修改父組件傳的值并刷新自己的頁面?但是并不會修改父組件中的值,這篇文章主要介紹了vue組件傳值(高級)、屬性傳值、反向傳值、跨級傳值,需要的朋友可以參考下2022-09-09Vue結(jié)合ElementUI實現(xiàn)數(shù)據(jù)請求和頁面跳轉(zhuǎn)功能(最新推薦)
我們在Proflie.vue實例中,有beforeRouteEnter、beforeRouteLeave兩個函數(shù)分別是進入路由之前和離開路由之后,我們可以在這兩個函數(shù)之內(nèi)進行數(shù)據(jù)的請求,下面給大家分享Vue結(jié)合ElementUI實現(xiàn)數(shù)據(jù)請求和頁面跳轉(zhuǎn)功能,感興趣的朋友一起看看吧2024-05-05Vue路由傳遞參數(shù)與重定向的使用方法總結(jié)
路由的本質(zhì)就是一種對應(yīng)關(guān)系,比如說我們在url地址中輸入我們要訪問的url地址之后,瀏覽器要去請求這個url地址對應(yīng)的資源,下面這篇文章主要給大家介紹了關(guān)于Vue路由傳遞參數(shù)與重定向的使用方法,需要的朋友可以參考下2022-10-10VUE Error: getaddrinfo ENOTFOUND localhost
這篇文章主要介紹了VUE Error: getaddrinfo ENOTFOUND localhost,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05vue-router實現(xiàn)編程式導(dǎo)航的代碼實例
今天小編就為大家分享一篇關(guān)于vue-router實現(xiàn)編程式導(dǎo)航的代碼實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01解決vue net :ERR_CONNECTION_REFUSED報錯問題
這篇文章主要介紹了解決vue net :ERR_CONNECTION_REFUSED報錯問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08element-ui中如何給el-table的某一行或某一列加樣式
本文主要介紹了element-ui中怎么給el-table的某一行或某一列加樣式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01