vue router 組件的高級(jí)應(yīng)用實(shí)例代碼
1 動(dòng)態(tài)設(shè)置頁(yè)面標(biāo)題
頁(yè)面標(biāo)題是由 <title></title> 來控制的,因?yàn)?SPA 只有一個(gè) HTML,所以當(dāng)切換到不同的頁(yè)面時(shí),標(biāo)題是不會(huì)發(fā)生變化的。必須通過 JavaScript 來修改 <title></title> 中的內(nèi)容:
window.document.title ='xxx'
有一種思路是在每個(gè)頁(yè)面的 *.vue 的 mounted 鉤子函數(shù)中,通過 JavaScript 來修改 <title></title> 中的內(nèi)容。這種方式固然可行,但如果頁(yè)面很多,就會(huì)顯著增加維護(hù)成本,而且修改邏輯都是一樣的。有沒有更好的方法呢?
我們可以利用 vue-router 組件的導(dǎo)航鉤子 beforeEach 函數(shù),在路由發(fā)生變化時(shí),統(tǒng)一設(shè)置。
import VueRouter from 'vue-router';
...
//加載 vue-router 插件
Vue.use(VueRouter);
/*定義路由匹配表*/
const Routers = [{
path: '/index',
component: (resolve) => require(['./router/views/index.vue'], resolve),
meta: {
title: '首頁(yè)'
}
},
//一次性加載
// {
// path: '/index',
// component: require('./router/views/index.vue')
// },
{
path: '/about',
component: (resolve) => require(['./router/views/about.vue'], resolve),
meta: {
title: '關(guān)于'
}
},
{
path: '/article/:id',
component: (resolve) => require(['./router/views/article.vue'], resolve)
}
,
{//當(dāng)訪問的頁(yè)面不存在時(shí),重定向到首頁(yè)
path: '*',
redirect: '/index'
}
]
//路由配置
const RouterConfig = {
//使用 HTML5 的 History 路由模式
mode: 'history',
routes: Routers
};
//路由實(shí)例
const router = new VueRouter(RouterConfig);
//動(dòng)態(tài)設(shè)置頁(yè)面標(biāo)題
router.beforeEach((to, from, next) => {
window.document.title = to.meta.title;
next();
})
new Vue({
el: '#app',
router: router,
render: h => h(Hello)
})
我們?cè)诼酚善ヅ浔碇?,為那些需要?biāo)題的頁(yè)面,配置了 meta title 屬性:
meta: {
title: 'xxx'
}
然后在 beforeEach 導(dǎo)航鉤子函數(shù)中,從路由對(duì)象中獲取 meta title 屬性,用于標(biāo)題設(shè)置。beforeEach 有三個(gè)入?yún)ⅲ?/p>
參數(shù) 說明
| 參數(shù) | 說明 |
|---|---|
| to | 當(dāng)前導(dǎo)航,即將要進(jìn)入的路由對(duì)象。 |
| from | 當(dāng)前導(dǎo)航,即將要離開的路由對(duì)象。 |
| next | 調(diào)用 next() 之后,才會(huì)進(jìn)入下一步。 |
效果:

2 長(zhǎng)頁(yè)面跳轉(zhuǎn)自動(dòng)返回頂端
假設(shè)第一個(gè)頁(yè)面較長(zhǎng),用戶滾動(dòng)查看到底部,這時(shí)如果又跳轉(zhuǎn)到另一個(gè)頁(yè)面,那么滾動(dòng)條是會(huì)默認(rèn)停在上一個(gè)頁(yè)面的所在位置的。這種場(chǎng)景比較好的設(shè)計(jì)是:跳轉(zhuǎn)后會(huì)自動(dòng)返回頂端。這可以通過 afterEach 鉤子函數(shù)來實(shí)現(xiàn),代碼如下:
router.afterEach((to, from, next) => {
window.scrollTo(0, 0);
});
組合使用 beforeEach 與 afterEach,還可以實(shí)現(xiàn):從一個(gè)頁(yè)面跳轉(zhuǎn)到另一個(gè)頁(yè)面時(shí),出現(xiàn) Loading 動(dòng)畫,當(dāng)新頁(yè)面加載后,再結(jié)束動(dòng)畫。
3 登陸驗(yàn)證
某些頁(yè)面設(shè)置了權(quán)限,只有賬號(hào)登陸過,才能訪問;否則跳轉(zhuǎn)到登錄頁(yè)。假設(shè)我們使用 localStorage 來判斷是否登陸。
HTML5 的 localStorage 特性,用于本地存儲(chǔ)。它的出現(xiàn),解決了 cookie 存儲(chǔ)空間不足的問題 cookie 中每條 cookie 的存儲(chǔ)空間只有 4k) ,而 localStorage 中一般是 5M,這在不同的瀏覽器中 大小略有不同 。
router.beforeEach((to, from, next) => {
if (window.localStorage.getItem('token')) {
next();
} else {
next('/login');
}
});
next() 入?yún)ⅲ绻?false,會(huì)不導(dǎo)航;如果為路徑,則會(huì)導(dǎo)航到指定路徑下的頁(yè)面。
總結(jié)
以上所述是小編給大家介紹的vue router 組件的高級(jí)應(yīng)用實(shí)例代碼,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
vue?長(zhǎng)列表數(shù)據(jù)刷新的實(shí)現(xiàn)及思考
這篇文章主要為大家介紹了vue?長(zhǎng)列表數(shù)據(jù)刷新的實(shí)現(xiàn)及思考,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
element表格數(shù)據(jù)部分模糊的實(shí)現(xiàn)代碼
這篇文章給大家介紹了element表格數(shù)據(jù)模糊的實(shí)現(xiàn)代碼,文中有詳細(xì)的效果展示和實(shí)現(xiàn)代碼供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下2024-01-01
vue+elemen實(shí)現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn)
el-tooltip組件本身就是懸浮提示功能,在對(duì)它進(jìn)行二次封裝時(shí),實(shí)現(xiàn)超出的文本浮現(xiàn),本文就來介紹一下vue+elemen實(shí)現(xiàn)el-tooltip在文本超出區(qū)域后浮現(xiàn),感興趣的可以了解一下2023-12-12
Vue監(jiān)聽使用方法和過濾器實(shí)現(xiàn)
這篇文章主要介紹了Vue監(jiān)聽使用方法和過濾器實(shí)現(xiàn),過濾器為頁(yè)面中數(shù)據(jù)進(jìn)行強(qiáng)化,具有局部過濾器和全局過濾器2022-06-06
el-table表頭使用el-dropdown出現(xiàn)兩個(gè)下拉框的問題及解決方法
本文給大家分享el-table在固定右邊列時(shí),表頭使用el-dropdown會(huì)出現(xiàn)兩個(gè)下拉框的解決方法,感興趣的朋友跟隨小編一起看看吧2024-07-07
vue父組件傳值子組件報(bào)錯(cuò)Avoid?mutating?a?prop?directly解決
這篇文章主要為大家介紹了vue父組件傳值子組件報(bào)錯(cuò)Avoid?mutating?a?prop?directly解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
如何在Vue.js中實(shí)現(xiàn)標(biāo)簽頁(yè)組件詳解
這篇文章主要給大家介紹了關(guān)于如何在Vue.js中實(shí)現(xiàn)標(biāo)簽頁(yè)組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
element-ui中的select下拉列表設(shè)置默認(rèn)值方法
今天小編就為大家分享一篇element-ui中的select下拉列表設(shè)置默認(rèn)值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08

