首页 > 其他分享 >【第20章】Vue实战篇之Vue Router(路由)

【第20章】Vue实战篇之Vue Router(路由)

时间:2024-06-19 19:59:18浏览次数:9  
标签:实战篇 Vue views router vue import Router 路由

文章目录


前言

Vue Router 是 Vue.js 的官方路由。它与 Vue.js 核心深度集成,让用 Vue.js 构建单页应用变得轻而易举。功能包括:

  • 嵌套路由映射
  • 动态路由选择
  • 模块化、基于组件的路由配置
  • 路由参数、查询、通配符
  • 展示由 Vue.js 的过渡系统提供的过渡效果
  • 细致的导航控制
  • 自动激活 CSS 类的链接
  • HTML5 history 模式或 hash 模式
  • 可定制的滚动行为
  • URL 的正确编码

一、使用Vue-Router

1.安装

npm install vue-router@4

在这里插入图片描述

2. 创建路由器实例

router.js

import { createWebHistory, createRouter } from 'vue-router'

import LoginView from '@/views/Login.vue'
import HomeView from '@/views/Home.vue'

const routes = [
  { path: '/', component: HomeView },
  { path: '/login', component: LoginView }
]

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

3. 注册路由器插件

main.js

import './assets/main.scss'

import { createApp } from 'vue'
import App from './App.vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import router from './router/router.js'

const app = createApp(App)
app.use(ElementPlus)
app.use(router)
app.mount('#app')

和大多数的 Vue 插件一样,use() 需要在 mount() 之前调用。

如果你好奇这个插件做了什么,它的职责包括:

  1. 全局注册 RouterView 和 RouterLink 组件。
  2. 添加全局 $router 和 $route 属性。
  3. 启用 useRouter() 和 useRoute() 组合式函数。
  4. 触发路由器解析初始路由。

4. 根组件

App.vue

<script setup>

</script>

<template>
   <main>
    <RouterView />
  </main>
</template>

<style scoped>

</style>

二、访问路由器

这里演示场景为登录成功后,通过路由从登录界面跳转到首页。

1.理论

Vue Router 可以使用组合式 API 或选项式 API 。

在本教程中,我们常常以 router 作为路由器实例提及。即由 createRouter() 返回的对象。在应用中,访问该对象的方式取决于上下文。例如,在组合式 API 中,它可以通过调用 useRouter() 来访问。在选项式 API 中,它可以通过 this.$router 来访问。

类似地,当前路由会以 route 被提及。基于不同 API 风格的组件,它可以通过 useRoute() 或 this.$route 来访问。

2.使用

import { useRoute, useRouter } from 'vue-router'

const loginFormRef = ref(null)
const router = useRouter()
const loginUser = async () => {
    let result = await loginService(registerData.value)
    let message = result.message
    if (result.code == 0) {
        ElMessage.success(message ? message : '登录成功!')
        //this.$router.push('/')//选项式
        router.push("/")//组合式
    } else {
        ElMessage.error(message ? message : '登录失败!')
    }
}

3. 展示

在这里插入图片描述

三、嵌套路由(子路由)

一些应用程序的 UI 由多层嵌套的组件组成。在这种情况下,URL 的片段通常对应于特定的嵌套组件结构,例如:

/user/johnny/profile                     /user/johnny/posts
+------------------+                  +-----------------+
| User             |                  | User            |
| +--------------+ |                  | +-------------+ |
| | Profile      | |  +------------>  | | Posts       | |
| |              | |                  | |             | |
| +--------------+ |                  | +-------------+ |
+------------------+                  +-----------------+

1. 准备文件

在这里插入图片描述

2. 配置路由

import { createWebHistory, createRouter } from 'vue-router'

import LoginView from '@/views/Login.vue'
import HomeView from '@/views/Home.vue'
import ArticleCategoryView from '@/views/article/ArticleCategory.vue'
import ArticleManageView from '@/views/article/ArticleManage.vue'
import UserAvatarView from '@/views/user/UserAvatar.vue'
import UserInfoView from '@/views/user/UserInfo.vue'
import UserResetPasswordView from '@/views/user/UserResetPassword.vue'

const routes = [
  { path: '/login', component: LoginView },
  { path: '/', component: HomeView,children:[
    { path: '/article/category', component: ArticleCategoryView },
    { path: '/article/manage', component: ArticleManageView },
    { path: '/user/avatar', component: UserAvatarView },
    { path: '/user/info', component: UserInfoView},
    { path: '/user/resetpassword', component: UserResetPasswordView},
  ]}
  
]

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

3. 菜单配置

<el-menu active-text-color="#ffd04b" background-color="#232323" text-color="#fff" router>
    <el-menu-item index="/article/category">
        <el-icon>
            <Management />
        </el-icon>
        <span>文章分类</span>
    </el-menu-item>
    <el-menu-item index="/article/manage">
        <el-icon>
            <Promotion />
        </el-icon>
        <span>文章管理</span>
    </el-menu-item>
    <el-sub-menu>
        <template #title>
            <el-icon>
                <UserFilled />
            </el-icon>
            <span>个人中心</span>
        </template>
        <el-menu-item index="/user/avatar">
            <el-icon>
                <User />
            </el-icon>
            <span>基本资料</span>
        </el-menu-item>
        <el-menu-item index="/user/info">
            <el-icon>
                <Crop />
            </el-icon>
            <span>更换头像</span>
        </el-menu-item>
        <el-menu-item index="/user/resetpassword">
            <el-icon>
                <EditPen />
            </el-icon>
            <span>重置密码</span>
        </el-menu-item>
    </el-sub-menu>
</el-menu>

4. 展示

在这里插入图片描述


总结

回到顶部
官方网站

标签:实战篇,Vue,views,router,vue,import,Router,路由
From: https://blog.csdn.net/qq_44824164/article/details/139577897

相关文章

  • 【第17章】Vue实战篇之注册界面
    文章目录前言一、搭建界面二、数据绑定1.定义响应数据2.绑定数据三、数据校验1.定义校验规则2.表单校验3.展示四、注册接口调用1.user.js2.Login.vue五、展示总结前言本章内容主要包含:注册界面搭建数据绑定表单校验调用后端接口一、搭建界面<scriptset......
  • MinIO分布式存储从0到Vue+SpringBoot整合开发 视频教程 下载
    inIO分布式存储从0到Vue+SpringBoot整合开发视频教程下载 001MinIO课程介绍.avi002WhatisMinIO?.avi003MinIO人工智能的数据存储服务.avi004什么是对象存储.avi005MinIO版权许可.avi006MinIO下载.avi007MinIO安装.avi008MinIO启动.avi009MinIOWeb管理......
  • MinIO分布式存储从0到Vue+SpringBoot整合开发 视频教程 下载
    inIO分布式存储从0到Vue+SpringBoot整合开发视频教程下载 001MinIO课程介绍.avi002WhatisMinIO?.avi003MinIO人工智能的数据存储服务.avi004什么是对象存储.avi005MinIO版权许可.avi006MinIO下载.avi007MinIO安装.avi008MinIO启动.avi009MinIOWeb管理......
  • 在Vue 2中使用Swiper,你需要安装与Vue 2兼容的Swiper版本
    在Vue2中使用Swiper,你需要安装与Vue2兼容的Swiper版本,并且通常还需要安装vue-awesome-swiper这个Vue组件来更方便地集成Swiper。以下是如何在Vue2项目中使用Swiper的步骤:1.安装Swiper和vue-awesome-swiper首先,你需要通过npm或yarn来安装Swiper和vue-awesome-swiper。确保安......
  • vue模板编译器
    vue模板编译器import{ASTElement,compile}from'vue-template-compiler';import{TableColumnDesc}from"@/components/table/base-table/type.ts";exportconstcodeAdapter=function(code:string):{tableCode:string;columns:TableC......
  • vue获取日期的封装方法
    ①封装js方法文件,我一般存放在utils文件夹下面。//封装的js文件名叫currentDate.jsconstgetDate={//对日期进行简单的增加和格式化操作,用于获取指定日期的后一天日期,并以特定格式返回。getIntroDuctionDay(dateTime){letdate=newDate(dateTime);......
  • Python文件嵌入html(vue)中,在浏览器中跑起来
    近期有个需求,之前项目是用python写的,需要包一层html,在浏览器中跑起来。推荐框架PyScript  https://pyscript.net/ 文档中有一些在线的example 在本地试了试<!doctypehtml><html><head><!--Recommendedmetatags--><metacharset="UTF-8"><metaname......
  • nuxt3+vue3+vite+TS实现国际化
    前言博主最近打算用Nuxt3重构了自己SSR博客,打算添加国际化功能,众所周知,实现国际化已是一个很常见的功能。用户可以根据自己的喜好,设置页面的自己合适的语言,从而实现国际化浏览。这样用户体验度会大大提升。博客用的nuxt3+vue3+vite+TS实现国际化,国际化用的vue-i18n,下面我给大......
  • Vue3如何绑定全局方法和变量
    Vue2中Vue.prototype绑定全局方法,此写法在Vue3已经不存在了。与任何全局的东西一样,应该谨慎使用。Vue3使用provide/inject或者app.config.globalProperties进行绑定如果全局属性与组件自己的属性冲突,组件自己的属性将具有更高的优先级。 一、provide/inject方法......
  • 基于SpringBoot+Vue的高校爱心捐赠系统设计与实现(源码+lw+部署+讲解)
    文章目录前言详细视频演示具体实现截图技术可行性分析技术简介后端框架SpringBoot前端框架Vue系统开发平台系统架构设计业务流程分析为什么选择我们自己的公众号(一点毕设)海量实战案例代码参考数据库参考源码及文档获取前言......