vue-router-全局导航守卫

为什么使用导航守卫?

考虑一个需求:在一个SPA应用中,如何改变网页的标题呢?
网页标题是通过< title >来显示的,但是SPA只有一个固定的HTML,切换不同的页面时,标题并不会改变
但是可以通过JavaScript来修改< title >的内容.window.document.title = ‘新的标题’
那么在Vue项目中,在哪里修改?什么时候修改比较合适呢?

matched
v. 敌得过;和…相配(match的过去式和过去分词)
adj. 相配的;敌得过的

普通的修改方式:
比较容易想到的修改标题的位置是每一个路由对应的组件.vue文件中
通过mounted声明周期函数,执行对应的代码进行修改即可
但是当页面比较多时,这种方式不容易维护(因为需要在多个页面执行类似的代码)

什么是导航守卫?
vue-router提供的导航守卫主要用来监听监听路由的进入和离开的。
vue-router提供了beforeEach和afterEach的钩子函数,它们会在路由即将改变前和改变后触发。

vue-router-全局导航守卫
补充一:如果后置钩子,也就是afterEach,不需要主动调用next()函数。
补充二:上面我们使用的导航守卫,被称之为全局守卫
路由独享的守卫
组件内的守卫

相关文章:

  • 2018-10-26
  • 2021-07-14
  • 2017-11-29
  • 2021-12-13
  • 2020-01-03
  • 2021-01-29
猜你喜欢
  • 2018-05-09
  • 2018-12-08
  • 2018-05-20
  • 2021-12-07
  • 2019-09-24
  • 2021-04-09
  • 2018-08-31
  • 2021-09-05
相关资源
相似解决方案