聊聊Vue中的Router(路由)

  • Vue构造的是一个单页面应用

    在 Vue 中,router(路由)用于定义应用的不同页面路径和组件之间的映射关系,通过路由从而实现页面的切换和导航功能

  • vue中所有的xxx.vue文件,都是路由组件,这些组件都会被vue读取,并编译成一段div结构,挂载在唯一的html中,所以想要实现组件之间的切换很简单

    但是想要将某些组件使用当成页面(每个页面对应的url都是唯一的)使用,默认情况是不能使用的那么我们需要将代码片段切换模拟成页面切换的手段,这就是vue-router

动画.gif

接下来我们讲解一下如何在项目中使用路由

  • 首先我们需要安装一下依赖,并将路由配置在vue里面
  npm install vue-router@4

安装成功后,将他配置在自己项目中

import router from './router/index'

const app = createApp(App)

app.use(router)

app.mount('#app')

现在我们的项目就集成里router

一级路由

接下来我们讲解如何使用路由
模拟实现掘金这个页面的一级路由切换

首先我们在项目中创建一个router文件夹,在里面创建一个index.js文件

image.png

在index.js代码书写

import { createRouter, createWebHistory } from "vue-router";
import Home from "../pages/Home.vue";
import Bot from "../pages/Bot.vue";

const routes = [
  {
    path: "/home",
    component: Home,
  },
  {
    path: "/bot",
    component: Bot,
  },
  {
    path: "/hot",
    component: () => import("../pages/Hot.vue"),
  },
];

const router = createRouter({
  history: createWebHistory(),
  routes: routes,
});

export default router;

这段代码我们创建了三个路由,分别是首页、bot、沸点

首先我们创建简易一个导航栏

<template>
  <div>
    <nav>
      <router-link to="/home">首页|</router-link>
      
      <router-link to="/bot">bot|</router-link>
      <router-link to="/hot">沸点|</router-link>
    </nav>

    <!-- 页面 -->
    <router-view></router-view>
  </div>
</template>

image.png

然后创建三个要跳转的页面

image.png

这样我们就实现了一级路由跳转了

动画.gif

二级路由

那么如何使用二级路由呢?

  • 首先需要创建对应的组件

image.png

  • 修改home页面的代码
<template>
  <div>
    <h2>home</h2>

    <div class="nav">
        <RouterLink to="/home/newest" >最新</RouterLink>
        <RouterLink to="/home/suggest">推荐</RouterLink>
    </div>
     
    <RouterView></RouterView>
  </div>
</template>

添加了两个路由跳转

image.png

  • 接下来就是重点,如何配置路由了
{
    path: "/home",
    component: Home,
    children: [
      {
        path: "/home/newest",
        component: Newest,
      },
      {
        path: "/home/suggest",
        component: Suggest,
      },
    ],
  },

这段路由配置代码定义了一个父路由 /home ,并且为它配置了两个子路由 /home/newest/home/suggest

当访问 /home 路径时,会渲染 Home 组件。当访问 /home/newest 路径时,会在 Home 组件的内部渲染 Newest 组件。同理,访问 /home/suggest 路径时,会在 Home 组件的内部渲染 Suggest 组件

现在就能实现二级路由跳转了

动画.gif

总结

通过本文,我们对路由的理解就更加的深刻了

Vue构造的是一个单页面应用,它只有一个html页面,想要将某些组件使用当成页面(每个页面对应的url都是唯一的)使用,默认情况是不能使用的那么我们需要将代码片段切换模拟成页面切换的手段,这就是vue-router(路由)

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值