vue-router 通过路由来实现切换头部标题
2019-04-25 06:52:13来源:博客园 阅读 ()
在做单页面应用程序时,一般页面布局头尾两块都是固定在布局页面,中间为是路由入口。这时访问页面时头部标题不会变,该问题的解决方案如下:
通过采用组件内路由卫士(beforeRouterEnter、beforeRouterUpdate)与路由元信息(meta) 来实现更新头部标题信息。点击查看文档
beforeRouterEnter:第一次进入时调用。
beforeRouterUpdate:重复使用当前组件时调用。
效果图如下:
注意看页面标题与图标变换
路由元信息(meta)配置
在路由元信息中配置页面标题,通过组件内路由卫士获取
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函数中获取路由元信息,并更新页面标题。
beforeRouteEnter:当第一次进入时,会被标题进行一次初始化操作
beforeRouteUpdate:当组件被重复调用时,执行更新操作。
<script> export default { name: "app", data() { return { title: "我的网站", url: '/', icon: '' } }, methods: { back() { this.$router.go(this.url); }, update(route) { [this.title, this.url, this.icon] = ["我的网站", '/', '']; if (!['', '/'].includes(route.path)) { // 判断是否根页面,用于切换标题与返回上一页或回到主页 [this.title, this.url, this.icon] = [route.meta.title || "", '-1', '']; } } }, beforeRouteEnter(to, from, next) { next(vm => { //回调函数,此时this指针不可用,可采用回调函数访问。 vm.update(to); }) }, beforeRouteUpdate(to, from, next) { this.update(to); next(); } }; </script>
原文链接:https://www.cnblogs.com/whnba/p/10760896.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- Vue学习之路由vue-router传参及嵌套小结(十) 2019-08-14
- Vue学习之路由vue-router小结(九) 2019-08-14
- vue-router 用户登陆 2019-04-25
- vue-router 页面布局 2019-04-20
- 关于vue-router 中参数传递的那些坑(params,query) 2019-03-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash