vue router 通過路由來實現(xiàn)切換頭部標題功能
在做單頁面應用程序時,一般頁面布局頭尾兩塊都是固定在布局頁面,中間為是路由入口。這時訪問頁面時頭部標題不會變,該問題的解決方案如下:
通過采用組件內(nèi)路由衛(wèi)士(beforeRouterEnter、beforeRouterUpdate)與路由元信息(meta) 來實現(xiàn)更新頭部標題信息。點擊查看文檔
beforeRouterEnter:第一次進入時調(diào)用。
beforeRouterUpdate:重復使用當前組件時調(diào)用。
效果圖如下:
注意看頁面標題與圖標變換
路由元信息(meta)配置
在路由元信息中配置頁面標題,通過組件內(nèi)路由衛(wèi)士獲取
const router = new Router({ mode: 'history', base: process.env.BASE_URL, routes: [ { path: "help", name: "help", meta: { title: "新手幫助" }, component: () => import('./views/Help.vue') }, { path: "page", name: "page", meta: { title: "寶貝信息" }, component: () => import('./views/Page.vue') } ] })
路由布局頁面
header 與 footer 是固定頭尾, main為路由入口。 title為頁面標題
<template> <div id="app"> <header class="header"> <button @click="back" class="t-xiaoxi iconfont" v-html="icon"></button> <h1 class="t-title">{{title}}</h1> <router-link to="/search" class="t-sousuo iconfont"></router-link> </header> <div class="main"> <router-view></router-view> </div> <footer class="footer"> // ... </footer> </div> </template>
在beforeRouteEnter、beforeRouteUpdate函數(shù)中獲取路由元信息,并更新頁面標題。
beforeRouteEnter:當?shù)谝淮芜M入時,會被標題進行一次初始化操作
beforeRouteUpdate:當組件被重復調(diào)用時,執(zhí)行更新操作。
<script> export default { name: "app", data() { return { title: "我的網(wǎng)站", url: '/', icon: '' } }, methods: { back() { this.$router.go(this.url); }, update(route) { [this.title, this.url, this.icon] = ["我的網(wǎng)站", '/', '']; if (!['', '/'].includes(route.path)) { // 判斷是否根頁面,用于切換標題與返回上一頁或回到主頁 [this.title, this.url, this.icon] = [route.meta.title || "", '-1', '']; } } }, beforeRouteEnter(to, from, next) { next(vm => { //回調(diào)函數(shù),此時this指針不可用,可采用回調(diào)函數(shù)訪問。 vm.update(to); }) }, beforeRouteUpdate(to, from, next) { this.update(to); next(); } }; </script>
總結(jié)
以上所述是小編給大家介紹的vue router 通過路由來實現(xiàn)切換頭部標題功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
Vue-cli 使用json server在本地模擬請求數(shù)據(jù)的示例代碼
本篇文章主要介紹了Vue-cli 使用json server在本地模擬請求數(shù)據(jù)的示例代碼,非常具有實用價值,需要的朋友可以參考下2017-11-11前端使用print.js實現(xiàn)打印功能(基于vue)
最近新接了一個需求,想要在前端實現(xiàn)打印功能,下面這篇文章主要給大家介紹了關(guān)于前端使用print.js實現(xiàn)打印功能(基于vue)的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-05-05Vue 微信端掃描二維碼蘋果端卻只能保存圖片問題(解決方法)
這幾天在做項目時遇到微信掃描二維碼的然后進入公眾號網(wǎng)頁巴拉巴拉的,然后就很順利的遇到了在安卓端掃碼的時候,順利的一塌糊涂,然后到了蘋果端的時候,就只能出現(xiàn)一個保存圖片,然后就寫一下記錄一下這問題的解決方法2020-01-01electron-builder打包vue2項目問題總結(jié)
這篇文章主要介紹了electron-builder打包vue2項目問題總結(jié),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-08-08