关于 Vue-router ,这些是需要知道的

简介: 关于 Vue-router ,这些是需要知道的

基础

路由规划配置,router/index.js

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Home,
  },
  {
    path: '/admin',
    name: 'admin',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import(/* webpackChunkName: "admin" */ '../views/Admin.vue'),
  },
];
AI 代码解读

路由出口导航,App.vue

<div id="app">
  <nav>
    <router-link to="/">home</router-link>
    <router-link to="/admin">admin</router-link>
  </nav>
  <router-view></router-view>
</div>
AI 代码解读

动态路由

路由配置

// router/index.js
{
  path: '/course/:name',
  component: () => import(/* webpackChunkName: "course" */ '../views/Detail.vue'),
}
AI 代码解读

路由跳转

<router-link :to="`/course/${c.name}`">
  {{ c.name }} - {{ c.price | currency('¥') }}
</router-link>
AI 代码解读

参数读取

<p>{{$route.params.name}}</p>
AI 代码解读

通配符

// router/index.js
{
  path: '*',
  component: () => import('../views/404.vue'),
}
AI 代码解读

嵌套路由

// router/index.js
{
  path: '/admin',
  name: 'admin',
  // route level code-splitting
  // this generates a separate chunk (about.[hash].js) for this route
  // which is lazy-loaded when the route is visited.
  component: () => import(/* webpackChunkName: "admin" */ '../views/Admin.vue'),
  children: [
    {
      path: '/admin/course/:name',
      name: 'course',
      component: () => import(/* webpackChunkName: "course" */ '../views/Detail.vue'),
    },
  ],
}
AI 代码解读

使用

<div class="admin">
  <img alt="Vue logo" src="../assets/logo.png">
  <a href="">test</a>
  <course-list :courses="courses"></course-list>
  <router-view></router-view>
</div>
AI 代码解读

组件复用注意事项

组件复用时嵌套,局部组件更新时,容器create不动,可以通过监听$route变化实现

export default {
  watch: {
    $route: {
      handler: () => {
        console.log('$route change');
      },
      immediate: true,
    }
  },
};
AI 代码解读

编程导航

// router.push(location, onComplete?, onAbort?);
// 字符串
router.push('home');
// 对象
router.push({ path: 'home' })
// 命名的路由
router.push({ name: 'user', params: { userId: '123' } })
// 带参数查询 => /register?plan=private
router.push({ path: 'register', query: { plan: 'private' } })
AI 代码解读

路由守卫

  • 全局守卫

    // router/index.js
    // 全局守卫
    router.beforeEach((to, from, next) => {
      // ...
      // to: Route 即将要进入的目标 路由对象
      // from: Route 当前导航正要离开的路由
      // next: Function 一定要调用该方法来 resolve 该钩子
    });
    AI 代码解读

    示例

    // 全局守卫
    const routes = [
      {
        path: '/admin',
        name: 'admin',
        meta: {
          auth: true,
        }
      }
    ]
    router.beforeEach((to, from, next) => {
      if (to.meta.auth) {
        if (window.isLogin) {
          next();
        } else {
          next(`/login?redirect=${to.fullPath}`);
        }
      } else {
        next();
      }
    });
    AI 代码解读
  • 路由独享守卫

    {
      path: '/admin',
      name: 'admin',
      // 全局守卫
      beforeEnter(to, from, next) => {
        if (window.isLogin) {
          next();
        } else {
          next(`/login?redirect=${to.fullPath}`);
        }
      }
    }
    AI 代码解读
  • 组件内守卫
    可以在路由组件内直接定义一下路由导航守卫

    • beforeRouteEnter
    • beforeRouteUpdate
    • beforeRouteLeave
    // Admin.vue
    beforeRouteEnter(to, from, next) {
      if (window.isLogin) {
        next();
      } else {
        next(`/login?redirect=${to.fullPath}`);
      }
    }
    AI 代码解读

数据获取时机

  • 路由导航前

    // 组件未渲染,通过next传递回调访问组件实例
    beforeRouteEnter(to, from, next) {
      getPost(to.params.id, post => {
        next(vm => vm.setData(post));
      });
    }
    // 组件已渲染,可以访问this直接赋值
    beforeRouteUpdate(to, from, next) {
      this.post = null;
      getPost(to.params.id, post => {
        this.setData(post);
        next();
      })
    }
    AI 代码解读
  • 路由导航后

    created() {
      this.fetchData();
    },
    watch: {
      '$route': 'fetchData',
    }
    AI 代码解读

addRoutes动态路由

// 动态添加路由
this.$router.addRoutes([
  {
    path: '/admin',
    name: 'admin',
    // ...
  }]);
AI 代码解读

组件缓存

利用keep-alive做组件缓存,保留组件状态,提高执行效率

<keep-alive :include="['admin']" max="10">
  <router-view></router-view>
</keep-alive>
AI 代码解读
使用include 或 exclude时使用的是组件的name

有两个可利用的钩子:activated、deactivated

路由懒加载

路由组件的懒加载能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应的组件

() => import(/* webpackChunkName: "group-about" */ "../views/About.vue")
AI 代码解读
目录
打赏
0
0
0
0
2
分享
相关文章
kde
|
7天前
|
Docker镜像加速指南:手把手教你配置国内镜像源
配置国内镜像源可大幅提升 Docker 拉取速度,解决访问 Docker Hub 缓慢问题。本文详解 Linux、Docker Desktop 配置方法,并提供测速对比与常见问题解答,附最新可用镜像源列表,助力高效开发部署。
kde
4474 12
国内如何安装和使用 Claude Code镜像教程 - Windows 用户篇
国内如何安装和使用 Claude Code镜像教程 - Windows 用户篇
737 3
Dify MCP 保姆级教程来了!
大语言模型,例如 DeepSeek,如果不能联网、不能操作外部工具,只能是聊天机器人。除了聊天没什么可做的。
1118 13
|
4天前
typora免费版,激活方法,Typora使用教程
Typora是一款简洁高效的Markdown编辑器,支持即时渲染。本教程涵盖安装方法、文件操作、视图控制、格式排版、字体样式及Markdown语法,助你快速上手使用Typora进行高效写作。
904 0
【保姆级图文详解】大模型、Spring AI编程调用大模型
【保姆级图文详解】大模型、Spring AI编程调用大模型
466 7
【保姆级图文详解】大模型、Spring AI编程调用大模型
2025年最新版最细致Maven安装与配置指南(任何版本都可以依据本文章配置)
本文详细介绍了Maven的项目管理工具特性、安装步骤和配置方法。主要内容包括: Maven概述:解释Maven作为基于POM的构建工具,具备依赖管理、构建生命周期和仓库管理等功能。 安装步骤: 从官网下载最新版本 解压到指定目录 创建本地仓库文件夹 关键配置: 修改settings.xml文件 配置阿里云和清华大学镜像仓库以加速依赖下载 设置本地仓库路径 附加说明:包含详细的配置示例和截图指导,适用于各种操作系统环境。 本文提供了完整的Maven安装和配置
2025年最新版最细致Maven安装与配置指南(任何版本都可以依据本文章配置)
企业如何用Data Agent实现数据价值效率的飞跃
在数字化转型背景下,数据被视为“新时代的石油”,但多数企业仍面临数据价值难以高效挖掘的困境。文章深入剖析了当前数据分析中存在的“被动响应”模式及其带来的四大挑战,并提出通过Data Agent实现主动智能与数据分析民主化的新路径。Data Agent基于大语言模型和强化学习技术,具备理解、思考与行动能力,能够从“人找数据”转变为“数据找人”,推动数据洞察从专业人员走向全员参与。
让AI时代的卓越架构触手可及,阿里云技术解决方案开放免费试用
阿里云推出基于场景的解决方案免费试用活动,新老用户均可领取100点试用点,完成部署还可再领最高100点,相当于一年可获得最高200元云资源。覆盖AI、大数据、互联网应用开发等多个领域,支持热门场景如DeepSeek部署、模型微调等,助力企业和开发者快速验证方案并上云。
367 25
让AI时代的卓越架构触手可及,阿里云技术解决方案开放免费试用
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问