Vue3开发极简入门(10):路由&嵌套路由
zhezhongyun 2025-05-26 20:13 26 浏览
电脑完蛋了,好不容易抢回来的文档
安装
npm install vue-router@4
这是创建了一个项目之后,再添加路由的办法。一般来说都是项目初始化的时候就添加路由,可以看Vue3开发极简入门(1):初始化
上面在问的时候,“是否引入 Vue Router 进行单页面应用开发?”,选“是”即可。
路由配置
新增文件src/router/index.ts:
import { createRouter, createWebHashHistory } from "vue-router";
import Car from '@/components/Car.vue';
import Driver from '@/components/Driver/index.vue'
import Applicant from '@/components/Applicant.vue'
import Staff from "@/views/Staff.vue";
import StaffInfo from "@/views/StaffInfo.vue";
const routes = [
{ path: '/', name: "index", component: Car },
{ path: '/driver', name: "driver", component: Driver },
{ path: '/applicant', name: "applicant", component: Applicant },
{
path: '/staff',
name: "staff",
component: Staff,
children: [
{
path: 'info',
name: "staffInfo"
}
]
}
]
const router = createRouter({
history: createWebHashHistory(),
routes,
})
export default router
说明:
- Car、Driver、Applicant是之前写的页面组件,在第一篇开头就说了,按照现行约定和最佳实践,这几个应该放在view或pages目录下面,components应该放一些可复用的组件,当时就是纯省事儿,放components了。后面的Staff、StaffInfo是为了本节内容新写的,就放views了。我这边也是为省事,以前的就不挪了。
- 这个代码应该是很清晰了,路由、嵌套路由(children),都不用解释。
- 我设置了Car的path为“/”。如果整个系统没有一个路径为“/”的组件,控制台会报
[Vue Router warn]: No match found for location with path "/";
其实倒没啥影响。
- 每个路由都配了name,是选配,但是在路由传参的时候很重要,建议都配上,详情后叙。
- 嵌套路由的path,最前面不用“/”。
- 嵌套路由的写法很重要,大家注意一下,详情后叙。
- history: createWebHashHistory()。是个关键点。这是不同的历史模式。
Memory模式(createMemoryHistory)。适合Node、SSR(服务端渲染),不推荐(但也可以)在浏览器应用中使用。
Hash模式(createWebHashHistory)。URL上会带一个#。对SEO不好,但是不需要对服务器层面进行特殊处理。如果是ToC的页面,不建议使用。本文采用此模式。
HTML5模式(createWebHistory)。URL不会带#,对SEO有好,但是需要根据服务器(Apache、Nginx、IIS等)的不同进行相应的配置,官网有说明,这也是服务端运维的知识点,本文不赘述。
修改main.ts:
import './assets/main.css'
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
createApp(App).use(router).mount('#app')
很简单,不解释。
修改App.vue:
<template>
<div id="app">
<header class="banner">
<h1>B端管理系统</h1>
</header>
<main class="container">
<aside class="sidebar">
<nav>
<ul>
<li><RouterLink to="/" active-class="activeLink">首页</RouterLink></li>
<li><RouterLink :to="{name:'driver'}" active-class="activeLink">司机管理</RouterLink></li>
<li><RouterLink :to="{path:'/applicant'}" active-class="activeLink">人员管理</RouterLink></li>
<li><RouterLink :to="{path:'/staff'}" active-class="activeLink">员工管理</RouterLink></li>
<!-- 添加更多导航项 -->
</ul>
</nav>
</aside>
<section class="content">
<RouterView/>
</section>
</main>
</div>
</template>
<script lang="ts" setup name="App">
</script>
<style scoped>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
.banner {
background-color: #42b983;
color: white;
width: 100%;
padding: 20px;
text-align: center;
position: fixed;
top: 0;
left: 0;
z-index: 1000;
}
.container {
display: flex;
margin-top: 60px;
height: calc(100vh - 120px);
width: 1024px;
}
.sidebar {
width: 250px;
background-color: #34495e;
color: white;
padding: 20px;
box-sizing: border-box;
}
.sidebar nav ul {
list-style-type: none;
padding: 0;
}
.sidebar nav ul li {
margin: 15px 0;
}
.content {
flex: 1;
padding: 20px;
box-sizing: border-box;
overflow-y: auto;
background-color: #ecf0f1;
}
.activeLink{
color: white;
}
</style>
- 样式是我网上瞎找的,不重要,一般都会用现有的UI框架(Element Plus等)。
- RouterView,也可以写作<router-view></router-view>。就是显示组件的区域,有点类似于以前的iframe。
- RouterLink,也可以写作<router-link></router-link>,就好像a标签一样。跳转页面的写法有:
to="path"。
:to="{name:'路由配置的name'}"。
:to="{name:'路由配置的path'}"。
至此,就可以通过点击,跳转至对应的组件了。Staff、StaffInfo后面讲传参的时候用。
相关推荐
- Trump Pushes for 15%-20% Minimum Tariffs on EU, Sticks to Auto Duties: Report
-
TMTPOST--U.S.PresidentDonaldTrumpistakingatougherstanceduringtradenegotiationswiththe...
- Note-15.使用A4988控制步进电机(dvp15mc11t控制步进电机)
-
如果需要控制一堆步进电机,那么只使用一个Arduino来控制,就会占用大量的处理时间,而无法处理其他事情,除非使用一个独立的专用步进电机驱动器:A4988。A4988只需两个引脚就可以控制双极步进电机...
- Negotiated settlement, not sanctions, the right way to end the Ukraine crisis
-
Negotiatedsettlement,notsanctions,therightwaytoendtheUkrainecrisis:ChinaDailyeditorial...
- U.S. Services May be Added to EU's Retaliatory Target List as More Members Seek Powerful Trade Tool If Talks Fail
-
TMTPOST--AmericanservicescouldbeaddedtotheEuropeanUnion’sretaliatorytargetlist,highlig...
- S7-1200伺服指令运动指令(s71200伺服位置控制实例)
-
1.MC_Halt指令名称:停止轴运行指令功能:停止所有运动并以组态的减速度停止轴。使用技巧:常用MC_Halt指令来停止通过MC_MoveVelocity指令触发的轴的运行。『注意』部分输入/输出管...
- Deepseek太强了!等了10年的Excel模糊下拉,竟然5分钟就搞定了
-
今天跟大家分享下我们如何通过Deepseek来编写VBA代码,制作模糊搜索的下拉菜单,这个等来十来年的功能,用Deepseek竟然几分钟就搞定了,不得不感叹AI工具的强大,我们以后能干的过AI吗,这真...
- 7.Unity物理关节(unity物理骨骼)
-
7.物理关节Unity的物理关节组件将刚体连接到另一个刚体或空间中的固定点。施加使刚体移动的力,关节限制可以限制移动。关节赋予刚体一定的自由度,从而使这些刚体具有不同的运动。Unity提供的物理关...
- 西门子111报文对应FB284引脚(西门子111报文详解)
-
西门子FB284是基于111报文的功能块,使用FB284比较方便,直接调用就可以控制V90伺服的定位控制。下面是整理的FB284对应的111报文。便于理解FB284功能块,更方面应用在实际项目中。11...
- 数据质量动态探查及相关前端实现(数据质量改进实践指南)
-
需求背景数据探查上线之前,数据验证都是通过写SQL方式进行查询的,从编写SQL,到解析运行出结果,不仅时间长,还会反复消耗计算资源,探查上线后,只需要一次探查,就可以得到整张表的探查报告,但后续...
- 阿里面试官:你连个排序算法都讲不明白?出门右拐吧
-
排序算法一表总览其他注意事项:计数排序中,kkk是整数的范围稳定性是指,序列中相同的数是否有可能交换顺序,例如序列中有两个8,顺序为888和8′8^{'}8′,如果在排序完之后,顺序有...
- 直流电机速度、位置双环控制简明教程
-
速度、位置的双环控制是我们在电机的控制系统中常用的方法,很实用。下面让我们来看一下内部实现的原理。1.速度闭环控制我们一般在速度闭环控制系统里面,使用增量式PI控制。而在我们的微处理器里面,因为控制器...
- 纳米机器人的精准定位与导航(纳米机器人怎么控制位置)
-
纳米机器人的精准定位与导航涉及多学科交叉技术,其“源码”(控制逻辑与算法)需结合硬件特性、环境感知和执行器设计。以下从控制原理、算法逻辑、关键技术实现等方面提供概念性思路(非实际可运行代码),供技术探...
- C语言进阶教程:多级指针的应用(c语言一级指针和二级指针)
-
在C语言中,指针可以指向变量的地址。多级指针(PointerstoPointers或MultilevelPointers)则是指向另一个指针地址的指针。这种概念可以扩展到任意级别(二级指针、...
- 被 Trac 的文件整理能力圈粉了!这 “香” 气挡不住
-
前阵子整理电脑文件夹时,我遇到了个麻烦:上千个文档和照片,要是手动一个个重命名、分类,不仅手得点到发麻,估计还得耗上一上午。于是我就琢磨着,能不能找个办法实现一键批量重命名。我先在网上搜了些批量改名软...
- Enhancer-轻量化的字节码增强组件包
-
一、问题描述当我们的业务发展到一定阶段的时候,系统的复杂度往往会非常高,不再是一个简单的单体应用所能够承载的,随之而来的是系统架构的不断升级与演变。一般对于大型的ToC的互联网企业来说,整个系统都是...
- 一周热门
- 最近发表
-
- Trump Pushes for 15%-20% Minimum Tariffs on EU, Sticks to Auto Duties: Report
- Note-15.使用A4988控制步进电机(dvp15mc11t控制步进电机)
- Negotiated settlement, not sanctions, the right way to end the Ukraine crisis
- U.S. Services May be Added to EU's Retaliatory Target List as More Members Seek Powerful Trade Tool If Talks Fail
- S7-1200伺服指令运动指令(s71200伺服位置控制实例)
- Deepseek太强了!等了10年的Excel模糊下拉,竟然5分钟就搞定了
- 7.Unity物理关节(unity物理骨骼)
- 西门子111报文对应FB284引脚(西门子111报文详解)
- 数据质量动态探查及相关前端实现(数据质量改进实践指南)
- 阿里面试官:你连个排序算法都讲不明白?出门右拐吧
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)
- CSS 水平对齐 (Horizontal Align) (30)
- opacity 属性 (32)