首页 > 其他分享 >学习笔记——路由

学习笔记——路由

时间:2024-07-20 14:29:17浏览次数:30  
标签:传参 router 笔记 学习 参数 跳转 path 路由

文章目录

VueRouter介绍


作用

vue 属于单页面应用,所谓路由,就是根据浏览器路径不同,用不同的视图组件替换这个页面内容,即不同的访问路径,对应不同的页面展示。


说明

VueRouter是Vue官方的一个路由插件,是一个第三方包。官网http://v3.router.vuejs.org/zh/

路由配置

路由组成

  • VueRouter:路由器,根据路由请求在路由视图中动态渲染对应的视图组件
  • :路由链接组件,浏览器会解析成
  • :路由视图组件,用来展示与路由路径匹配的视图组件,相当于占位符





VueRouter的使用步骤(5 + 2)

五个基础步骤(固定)

  1. 下载:下载vueRouter模块到当前工程,版本3.6.5(vue2对应的大版本是3)
yarn add vue-router@3.6.5
  1. 引入
import VueRouter from 'vue-router'
  1. 安装注册
Vue.use(VueRouter)
  1. 创建路由对象
const router = new VueRouter()
  1. 注入,将路由对象注入到new Vue实例中,建立关联
new Vue({
  render: h => h(App),
  router: router
}).$mount('#app')

两个核心步骤

  1. 创建需要的组件(views目录),配置路由规则

image.png

  1. 配置导航,配置与路由出口(路径匹配的组件显示的位置)

App.vue

<div class="footer_wrap">
  <a href="#/find">发现音乐</a>
  <a href="#/my">我的音乐</a>
  <a href="#/friend">朋友</a>
</div>
<div class="top">
  <router-view></router-view>
</div>

其中,<router-view></router-view>用来控制组件展示的位置。


router-link

介绍

router-linkvue-router提供的全局组件,用于替换a标签。

使用

<router-link to="/路径值"></router-link>
注意:必须传入to属性,指定路由路径值。

好处

router-link能跳转,能高亮(自带激活时的类名)。



声明式导航-两个类名

介绍

router-link自动给当前导航添加了两个高亮类名。
class="router-link-exact-active router-link-active"

特点

router-link-active
特点:模糊匹配(用得更多)
如:to=“/a” 可以匹配 /a   /a/b   /a/c …

router-link-exact-active
特点:精确匹配
如:to=“/a” 仅可以匹配 /a

自定义高亮类名

const router = new vueRouter ({
  routers: [
  ],
  // link自定义高亮类名
  linkActiveClass: '类名1',	// 配置模糊匹配的类名
  lingkExactActiveClass: '类名2'	// 配置请确匹配的类名
})


声明式导航-跳转传参

介绍

跳转传参,就是在跳转路由时,进行传值。
我们可以通过两种方式,在跳转的时候把所需要的参数传到其他页面中。

  • 查询参数传参
  • 动态路由传参


查询参数传递

语法

<router-link to="/path?参数名=值"></router-link>

对应页面组件接收传递过来的值

固定用法:$toute.query.参数名

基于参数发请求
<script>
  export default {
    name: '',
    created() {
      // 在created中,获取路由参数
      //this.$route.query.参数名 获取
      console.log(this.$route.query.key); 
    }
  }
</script>



动态路由传参

配置动态路由

动态路由后面的参数可以随便起名,但要有语义

const router = new VueRouter({
  routes: [
    ...,
    { 
      path: '/search/:words', 
      component: Search 
    }
  ]
})

注意:/search/:words 表示,必须要传参数。如果不传参数会未匹配到组件,显示空白。如果希望不穿参数也能匹配,可以加个可选符

const router = new VueRouter({
  routes: [
 	...
    { path: '/search/:words?', component: Search }
  ]
})

配置导航链接

<router-link to="/path/参数值"></router-link>

对应页面组件接受参数

$route.**params**.参数名
params后面的参数名要和动态路由配置的参数保持一致

基于参数发请求
<script>
  export default {
    name: '',
    created() {
      // 在created中,获取路由参数
      //this.$route.params.参数名 获取动态路由参数
      console.log(this.$route.params.words); 
    }
  }
</script>



查询参数传参 VS 动态路由传参

查询参数传参 (比较适合传多个参数)
  • 跳转:to="/path?参数名=值&参数名2=值"
  • 获取:$route.query.参数名

动态路由传参 (优雅简洁,传单个参数比较方便)
  • 配置动态路由:path: "/path/:参数名"
  • 跳转:to="/path/参数值"
  • 获取:$route.params.参数名

注意:动态路由也可以传多个参数,但一般只传一个



Vue路由-重定向

介绍

重定向就是当匹配path后,强制跳转path路径,解决了当网页打开时,url默认是/路径,此时未匹配到组件,页面会出现空白。

语法

{path: 匹配的路径,redirect: 重定向到的路径},

{ path: 匹配路径, redirect: 重定向到的路径 },
比如:
{ path:'/' ,redirect:'/home' }




Vue路由-404

作用

当路径找不到匹配时,给个提示页面

位置

404的路由,虽然配置在任何一个位置都可以,但一般都配置在其他路由规则的最后面

语法

path: "*" (任意路径) – 路由匹配规则是从上往下依次匹配,当前面不匹配就命中最后这个

import NotFind from '@/views/NotFind'

const router = new VueRouter({
  routes: [
    ...
    { path: '*', component: NotFind } //最后一个
  ]
})




Vue路由-模式设置

默认的路由的路径有#,看起来不自然, ,而能否切成真正路径形式呢?

  • hash路由(默认) 例如: [http://localhost:8080/#/home](http://localhost:8080/#/home)
const router = new VueRouter({
    mode:'hash', //默认是hash,因为是默认的,写不写都行
    routes:[]
})
  • history路由(常用) 例如: [http://localhost:8080/home](http://localhost:8080/home) (以后上线需要服务器端支持,开发环境webpack给规避掉了history模式的问题)
const router = new VueRouter({
  mode:'histroy', 
  routes:[]
  })




编程式导航-两种路由跳转方式

编程式导航:用JS代码来进行跳转

语法

两种语法:

  • path 路径跳转 (简易方便)
  • name 命名路由跳转 (适合 path 路径长的场景)

path路径跳转语法

特点:简易方便

//简单写法
this.$router.push('路由路径')

//完整写法
this.$router.push({
  path: '路由路径'
})

name命名路由跳转

特点:适合 path 路径长的场景
语法:

  • 路由规则,必须配置name配置项
{ name: '路由名', path: '/path/xxx', component: XXX },
  • 通过name来进行跳转
this.$router.push({
  name: '路由名'
})




编程式导航-path路径跳转传参

两种传参方式

1.查询参数
2.动态路由传参

传参

两种跳转方式,对于两种传参方式都支持:
path 路径跳转传参
name 命名路由跳转传参

path路径跳转传参(query传参)

//简单写法
this.$router.push('/路径?参数名1=参数值1&参数2=参数值2')
//完整写法
this.$router.push({
  path: '/路径',
  query: {
    参数名1: 参数值1,
    参数名2: 参数值2
  }
})

接受参数的方式依然是:$route.query.参数名


path路径跳转传参(动态路由传参)

//简单写法
this.$router.push(`/路径/参数值`)
//完整写法
this.$router.push({
  path: `/路径/参数值`
})

接受参数的方式依然是:$route.params.参数值
注意:path不能配合params使用



编程式导航-name命名路由传参

name 命名路由跳转传参 (query传参)

this.$router.push({
  name: '路由名字',
  query: {
    参数名1: 参数值1,
    参数名2: 参数值2
  }
})

name 命名路由跳转传参 (动态路由传参)

this.$router.push({
  name: '路由名字',
  params: {
    参数名: '参数值',
  }
})

标签:传参,router,笔记,学习,参数,跳转,path,路由
From: https://blog.csdn.net/2301_80093566/article/details/140569029

相关文章

  • C基础(学习)2024.7.19
             Linux基本命令,vi编译器的使用,简单的编程步骤,程序语言,gcc编译器编译过程,进制转换相关知识可以查看文档http://t.csdnimg.cn/CmqhC        数值表示,词法符号,变量,常量相关知识可以查看文档http://t.csdnimg.cn/jJIe2        运算符和输表达式......
  • Java计算机毕业设计老年教育学习系统(开题报告+源码+论文)
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着全球人口老龄化的加速,老年教育作为提升老年人生活质量、促进终身学习的重要途径,日益受到社会各界的关注。然而,传统教育模式在满足老年人多样化、......
  • 苍穹外卖学习笔记——第十一天
    数据统计(图形报表)ApacheEChartsApacheECharts是一款基于Javascript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。官网地址:https://echarts.apache.org/zh/index.html。使用Echarts,重点在于研究当前图表所需的数据格式。通常是需要后端提供符合格式......
  • Jupyter Notebook与机器学习:使用Scikit-Learn构建模型
    JupyterNotebook与机器学习:使用Scikit-Learn构建模型介绍JupyterNotebook是一款强大的交互式开发环境,广泛应用于数据科学和机器学习领域。Scikit-Learn是一个流行的Python机器学习库,提供了简单高效的工具用于数据挖掘和数据分析。本教程将详细介绍如何在JupyterNoteboo......
  • 零基础,快速学YOLO目标检查算法(YOLO—v1,2,3快速学习)
    一.深度学习经典检测方法1.two-stage(两阶段):Faster-rcnnMask-Rcnn系列,先有预选,预选完之后再通过预选得到最终结果。速度通常较慢,但效果不错2.one-stage(单阶段):YOLO系列,普通回归任务。最核心的优势,速度非常快,适合做实时检测任务,但效果通常情况不会太好二.指标分析map指标......
  • C++学习笔记
    第一章预备知识C++融合了三种不同的编程方式:过程性编程(C语言代表的)、面向对象编程(C语言基础上添加的类代表的)、泛型编程(C++模板支持)。Linux上源代码文件编译完后生成后缀.o的目标代码文件,然后执行链接后生成文件名为a.out(默认取名)的可执行程序。C++源文件名的后缀有.cpp......
  • [rCore学习笔记 016]实现应用程序
    写在前面本随笔是非常菜的菜鸡写的。如有问题请及时提出。可以联系:1160712160@qq.comGitHhub:https://github.com/WindDevil(目前啥也没有设计方法了解了特权级机制,实际上如果要设计一个应用程序就需要保证它符合U模式的要求,不要去访问S模式下的功能,那么其实现要点是:应......
  • PyQt5学习路线
    后续会根据该文章的路线逐步发布对应的教程,订阅专栏不迷路......
  • FFmpeg开发笔记(三十九)给Visual Studio的C++工程集成FFmpeg
    ​《FFmpeg开发实战:从零基础到短视频上线》一书的“第11章 FFmpeg的桌面开发”介绍了如何在Windows环境对Qt结合FFmpeg实现桌面程序,那么Windows系统通过VisualStudio开发桌面程序也是很常见的,下面就介绍如何在VisualStudio的C++工程中集成FFmpeg库和SDL2库。首先按照《FFmpe......
  • 超详细的MySQL基本使用教程(1) 黑马程序员javaweb学习笔记+练习(附带idea新版ui图形化页
    什么是数据库MySQL概述数据模型关系型数据库SQL简介小结DDL-数据库的设计数据库的常见操作选中该语句然后点运行就成功运行了可以直接用图形化界面进行操作跳转到控制台表的常见操作1.创建练习在db01中创建这张表其中comment是鼠标悬停在......