路由其实是网络工程中的一个术语:
路由的概念在软件工程中出现,最早是在后端路由中实现的,原因是web的发展主要经历了这样一些阶段:
早期的网站开发整个HTML页面是由服务器来渲染的.
但是, 一个网站, 这么多页面服务器如何处理呢?
上面的这种操作, 就是后端路由:
后端路由的缺点:
前端渲染的理解:
前后端分离阶段:
单页面富应用阶段:
前端路由的核心是什么呢?改变URL,但是页面不进行整体的刷新。


history接口是HTML5新增的, 它有六种模式改变URL而不刷新页面:


目前前端流行的三大框架, 都有自己的路由实现:
Vue Router 是 Vue.js 的官方路由:
vue-router是基于路由和组件的
安装Vue Router:
npm install vue-router
使用vue-router的步骤:



我们这里还有一个不太好的实现:
如何可以让路径默认跳到到首页, 并且

我们在routes中又配置了一个映射:
另外一种选择的模式是history模式:


router-link事实上有很多属性可以配置:
to属性:
replace属性:
active-class属性:
exact-active-class属性:
当打包构建应用时,JavaScript 包会变得非常大,影响页面加载:
其实这里还是我们前面讲到过的webpack的分包知识,而Vue Router默认就支持动态来导入组件:





很多时候我们需要将给定匹配模式的路由映射到同一个组件:

在router-link中进行如下跳转:

那么在User中如何获取到对应的值呢?


对于哪些没有匹配到的路由,我们通常会匹配到固定的某个页面

我们可以通过 $route.params.pathMatch获取到传入的参数:

这里还有另外一种写法:


什么是路由的嵌套呢?
但是呢,我们Home页面本身,也可能会在多个组件之间来回切换:
路由的嵌套配置:在一层路由中添加 children属性

有时候我们希望通过代码来完成页面的跳转,比如点击的是一个按钮:

当然,我们也可以传入一个对象:

如果是在setup中编写的代码,那么我们可以通过 useRouter 来获取:

我们也可以通过query的方式来传递参数:

在界面中通过 $route.query 来获取参数:
使用push的特点是压入一个新的页面,那么在用户点击返回时,上一个页面还可以回退,但是如果我们希望当前页面是一个替换操作,那么可以使用replace:

router的go方法:

router也有back:通过调用 history.back() 回溯历史。相当于 router.go(-1);
router也有forward:通过调用 history.forward() 在历史中前进。相当于 router.go(1);
某些情况下我们可能需要动态的来添加路由:
如果我们是为route添加一个children路由,那么可以传入对应的name:


删除路由有以下三种方式:



路由的其他方法补充:

比如我们完成一个功能,只有登录后才能看到其他页面:


Vue-Router还提供了很多的其他守卫函数,目的都是在某一个时刻给予我们回调,让我们可以更好的控制程序的流程或者功能:导航守卫 | Vue Router
我们一起来看一下完整的导航解析流程:
beforeRouteLeave 守卫。beforeEach 守卫。beforeRouteUpdate 守卫(2.2+)。beforeEnter。beforeRouteEnter。beforeResolve 守卫(2.5+)。afterEach 钩子。beforeRouteEnter 守卫中传给 next 的回调函数,创建好的组件实例会作为回调函数的参数传入。
import {createRouter, createWebHashHistory, createWebHistory} from 'vue-router'// import Home from '../Views/Home.vue'
// import About from '../Views/About.vue'// 路由的懒加载
// const Home = () => import(/* webpackChunkName: 'home' */"../Views/Home.vue")
// const About = () => import(/* webpackChunkName: 'about' */"../Views/About.vue")// 创建一个路由: 映射关系
const router = createRouter({// 指定采用的模式: hashhistory: createWebHashHistory(),// history: createWebHistory(),// 映射关系routes: [{path: "/",redirect: "/home" // 跳转页面},{name: "home",path: "/home",component: () => import("../Views/Home.vue"),meta: {name: "why",age: 18},children: [{path: "/home",redirect: "/home/recommend"},{path: "recommend", // /home/recommendcomponent: () => import("../Views/HomeRecommend.vue")},{path: "ranking", // /home/rankingcomponent: () => import("../Views/HomeRanking.vue")}]},{name: "about",path: "/about",component: () => import("../Views/About.vue")},{path: "/user/:id",component: () => import("../Views/User.vue")},{path: "/order",component: () => import("../Views/Order.vue")},{path: "/login",component: () => import("../Views/Login.vue")},{// 上面路径匹配不成功后,使用这个匹配任意路径// path: "/:pathMatch(.*)", // 后面不加上 * 对路径不进行解析path: "/:pathMatch(.*)*",component: () => import("../Views/NotFound.vue")}]
})// 1.动态管理路由
let isAdmin = true
if (isAdmin) {// 一级路由router.addRoute({path: "/admin",component: () => import("../Views/Admin.vue")})// 添加vip页面router.addRoute("home", {path: "vip",component: () => import("../Views/HomeVip.vue")})
}// 获取router中所有的映射路由对象
console.log(router.getRoutes())// 2.路由导航守卫
// 进行任何的路由跳转之前, 传入的beforeEach中的函数都会被回调
// 需求: 进入到订单(order)页面时, 判断用户是否登录(isLogin -> localStorage保存token)
// 情况一: 用户没有登录, 那么跳转到登录页面, 进行登录的操作
// 情况二: 用户已经登录, 那么直接进入到订单页面
router.beforeEach((to, from) => {// 1.进入到任何别的页面时, 都跳转到login页面// if (to.path !== "/login") {// return "/login"// }// 2.进入到订单页面时, 判断用户是否登录const token = localStorage.getItem("token")if (to.path === "/order" && !token) {return "/login"}
})export default router
About: {{ $route.query }}
Admin
哈哈哈哈哈哈哈
哈哈哈哈哈哈哈
哈哈哈哈哈哈哈
哈哈哈哈哈哈哈
哈哈哈哈哈哈哈
哈哈哈哈哈哈哈
Home
推荐 排行
各种榜单
- 热歌榜
- 新歌榜
- 原创榜
- 歌手榜单
HomeRecommend
- 推荐歌单1
- 推荐歌单2
- 推荐歌单3
- 推荐歌单4
HomeVip
登录页面
NotFound: 您当前的路径{{ $route.params.pathMatch }}不正确, 请输入正确的路径!
订单页面
- 订单1
- 订单2
- 订单3
- 订单4
- 订单5
User: {{ $route.params.id }}
App Content
首页 关于 用户123 用户321 订单 首页
import { createApp } from 'vue'
import router from './router'
import App from './App.vue'// localStorage.setItem("token", "coderwhy")const app = createApp(App)
app.use(router)
app.mount('#app')
上一篇:Java寒假作业——编程题