【b站前端-小鑫】Vue Router(路由)快速掌握(入门到精通5节课)

本文主要是介绍【b站前端-小鑫】Vue Router(路由)快速掌握(入门到精通5节课),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

课程地址:【Vue Router(路由)快速掌握(入门到精通5节课)】 https://www.bilibili.com/video/BV1aP4y1W7Uz/?share_source=copy_web&vd_source=b1cb921b73fe3808550eaf2224d1c155

目录

1 Vue Router

1.1 Vue Router的安装

1.2 创建路由

1.2.1 router-index.js创建路由

1.2.2 main.js里引入路由

1.2.3 在App.vue里使用路由

1.2.4 结果

1.3 路由配置

1.3.1 路由配置

1.3.2 路由模式

1.3.3 二级路由

1.4 路由跳转

1.4.2 tag属性

1.4.3 跳转属性target

1.4.4 replace属性

1.4.5 to属性

1.4.6 其他跳转方式

1.4.7 传递参数

1 普通方式

2 参数不要在url中显示

3 页面刷新后还可以获取到参数

1.4.8 跳转新页面

1.5 路由守卫

1.5.1 什么是路由守卫

1.5.2 全局守卫

1 beforeEach

2 afterEach

1.5.3 局部守卫

1 beforeRouteEnter

2 beforeRouteUpdate

3 beforeRouteLeave

1.5.4 路由守卫

1 beforeEnter


1 Vue Router

Vue Router,路由。

当项目逐渐复杂以后,可能会进行跳转,那就要使用到Vue Router。

1.1 Vue Router的安装

使用Vue Router要进行安装。

安装 | Vue Router

npm install vue-router -d

在package.json里可以看到安装的依赖(-d命令会使vue router安装到devDependencies里)。

1.2 创建路由

1.2.1 router-index.js创建路由

src>router>index.js里,创建路由

1.2.2 main.js里引入路由

引入到main.js里

1.2.3 在App.vue里使用路由

显示组件

在App.vue里使用router-view标签使用路由

1.2.4 结果

效果

a组件

要显示b组件,那么路径是/b

c组件这里就不演示了。

1.3 路由配置

1.3.1 路由配置

输入匹配不上的路由,如何进行处理呢?

输入未匹配的路由时,

 页面默认跳转'/'对应的页面。

1.3.2 路由模式

井号 # 为什么会存在?

# 对应模式是hash。

hash表示使用路由的形式类似 a链接(本地跳转)的一种形式。相当于是一个锚点。

mode默认是history.

是一种H5方式的路由。

在hash的基础上,访问路径去掉 # 以及后面的/.

效果

可以正常运行项目。

b组件

c组件就不演示了。

注意:如果去除 # 后,正式项目在进行一些部署时,需要后端配置。因为如果没有 # ,相当于浏览器向服务器发送一次请求,对应数据库没有这种请求,就会抛出404错误。

(没看懂)

测试学习阶段可以使用hash值进行。hash值要在路径中加上 #。

1.3.3 二级路由

前面是针对一级路由,现在针对二级路由进行配置。

比如,当前a组件下还有aa子组件。

效果

在路径输入aa,aa组件不生效。

欲在何处渲染,则在何处使用router-view标签。(见App.vue)

效果

此时aa组件生效。

同理。

还可以添加其他属性

在a组件打印看下对象内容。

打印结果

1.4 路由跳转

已经可以实现对不同的路由显示不同的内容,以及显示子路由,children里还可以显示子路由。

路由跳转:router-link。

本质上是一个 a 标签。

示例

运行

就是一个a标签

效果

点击跳转到b标签可以显示b组件。

1.4.2 tag属性

改造 a 标签为其他标签。

示例:改造为 div 标签。

效果

此时跳转到a是一个 div 标签,不再是 a 标签了。

也可以变为其他标签,比如span标签。

效果

1.4.3 跳转属性target

 a标签的属性也适用于 router-link。

示例

效果

点击跳转到b,会打开一个新标签页。


 

1.4.4 replace属性

replace:当前跳转没有历史记录。

添加replace

1.4.5 to属性

to也可以是对象类型。

router的index.js

App.vue里的to的name的‘c’对应路由name的‘c’。

效果

可以实现跳转到c组件。

结论:to可以接收字符串形式,也可以接收对象形式。

1.4.6 其他跳转方式

使用方法实现路由跳转。

使用this.$router.push('/'),可以跳转到a组件。

同理,以下写法都可以实现路由跳转

② path

③ name

④ 无历史记录

1.4.7 传递参数

1 普通方式

this.$router.push方法传值,this.$router.query取传递的参数。

效果

传递的参数在url携带。

同时可以获取到参数。

(其实这种传参方式,页面刷新后还是可以获取到参数的。)

2 参数不要在url中显示

要求:参数不要在url中。

效果,此时url不再携带参数,且仍然可以获取到参数。

但是此时刷新页面,再点击query按钮,无法获取到参数。因为此时没有地方可以存value参数值。

3 页面刷新后还可以获取到参数

在router的index.js文件里,添加以下代码

push方法的name也改成b

效果

push一下跳转到b组件,然后query,可以获取到value值

刷新页面,直接点击query按钮,还是可以获取到参数的。

可以发现,如果路由上不配置/:value的话,路由就没有值。如果配置后,那么导航上与query一样带上要传递参数的值。

1.4.8 跳转新页面

效果

点击push按钮,打开到一个新标签页。

补充:传参

总结:实现跳转。

之前使用router-link实现跳转,但是书写比较麻烦。可以使用点击事件代替实现路由跳转。

包括push方法,resolve方法,replace方法(不留历史记录)

1.5 路由守卫

1.5.1 什么是路由守卫

当进入一个页面,但是没有登陆,此时该页面会提示需要登陆才可继续访问页面。相当于路由拦截。

1.5.2 全局守卫

1 beforeEach

点击跳转到c,alert提示

这里就拦截跳转c组件的动作。

2 afterEach

跳转之后

1.5.3 局部守卫

1 beforeRouteEnter

进入组件之前

多次点击“跳转到c”,控制台只会打印一次结果。

2 beforeRouteUpdate

传递一个变化的参数

结果

不知道为啥,params里没有传递的日期参数,可能有bug吧。

3 beforeRouteLeave

离开组件之前

1.5.4 路由守卫

1 beforeEnter

up说的听不清,不知道是啥守卫

这篇关于【b站前端-小鑫】Vue Router(路由)快速掌握(入门到精通5节课)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/954238

相关文章

Java Lettuce 客户端入门到生产的实现步骤

《JavaLettuce客户端入门到生产的实现步骤》本文主要介绍了JavaLettuce客户端入门到生产的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录1 安装依赖MavenGradle2 最小化连接示例3 核心特性速览4 生产环境配置建议5 常见问题

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Spring Gateway动态路由实现方案

《SpringGateway动态路由实现方案》本文主要介绍了SpringGateway动态路由实现方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录前沿何为路由RouteDefinitionRouteLocator工作流程动态路由实现尾巴前沿S

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的