IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue - vue-router - 导航守卫 -> 正文阅读

[JavaScript知识库]Vue - vue-router - 导航守卫


一、需求

当点击到哪个模块的时候, 就把title修改为哪个模块的名字.

二、方法一 : 使用生命周期函数

  • created() : 当组件被创建的时候回调created函数
  • mounted() : 当组件被挂载到DOM上的时候回调mounted函数
  • updated() : 当页面发生更新的时候回调updated函数
<template>
  <div>
    <h3>
      我是Home
    </h3>
    <router-link to="/home/news" tag="button">新闻</router-link>
    <router-link to="/home/message" tag="button">消息</router-link>
    <router-view></router-view>
  </div>
</template>

<script>
  export default {
    name: 'Home',
    // 当组件被创建的时候修改title
    created() {
      document.title = '首页'
    },
  }
</script>

<style>
  .router-link-active {
    color: red;
  }
</style>

这样的做法有一个弊端, 就是每个组件都需要添加created函数, 造成代码冗余

二、方法二 : 监听全局跳转

使用 router.beforeEach() 监听全局跳转
beforeEach()函数里面接收一个函数, 函数又需要三个参数 (to, from, next), 从from跳转到to
里面必须调用next()方法, 否则将无法跳转

2.1 在路由里面添加源数据

const routes = [
  {
    path: '',
    redirect: '/home'
  },
  {
    path: '/home',
    component: Home,
    meta: {
      title: '首页'
    },
    children: [{
      path: '',
      redirect: '/home/news',
    },
    {
      path: 'news',
      component: HomeNews,
    },
    {
      path: 'message',
      component: HomeMessage,
    }]
  },
  {
    path: '/about',
    component: About,
    meta: {
      title: '关于'
    }
  },
  {
    path: '/user/:userid',
    component: User,
    meta: {
      title: '用户'
    }
  },
  {
    path: '/profile',
    component: Profile,
    meta: {
      title: '配置'
    }
  }
]

2.2 从from跳转到to

router.beforeEach((to, from, next) => {
  // 把源数据里面的title赋值给元素的title
  document.title = to.matched[0].meta.title
  next()
})

三、导航守卫

beforeEach()也称为前置钩子 , 是全局导航守卫
除了beforeEach() 还有 afterEach() , 是全局后置钩子.

四、路由独享的守卫

可以在路由配置上直接定义 beforeEnter守卫

const routes = [
  {
    path: '/home',
    component: Home,
    meta: {
      title: '首页'
    },
    beforeEnter: (to, from, next) => {
    	// ...
    }
  }
]

五、组件内的导航守卫

5.1 beforeRouterEnter()

beforeRouterEnter(to, from, next){
	// 在渲染该组件的对应录用后被confirm前调用
	// 不能获取组件实例 this
	// 因为当守卫执行前, 组件实例还没被创建
}

5.2 beforeRouterUpdate()

beforeRouterUpdate(to, from, next){
	// 在当前路由改变, 但是该组件被复用时调用
	// 例如: 一个带有动态参数的路径, /foo/:id. 在/foo/1 和 /foo/2之间跳转的时候, 由于会渲染同样的Foo组件, 因此组件实例会被复用, 这个钩子就会在这个情况下被调用
	// 可以访问组件实例 this
}

5.1 beforeRouterLeave()

beforeRouterLeave(to, from, next){
	// 导航离开该组件的对应路由时调用
	// 可以访问组件实例 this
}
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-21 15:16:46  更:2021-08-21 15:16:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:29:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码