Vue Router基础知识整理

Vue Router基础知识整理

  • 1. 安装与使用(Vue3)
    • 安装
    • 使用
  • 2. 配置路径别名@和VSCode路径提示(了解)
  • 3. 使用查询字符串或路径传参
    • query
    • 动态路由 与 params
  • 4. router-link、定义别名、定义路由名称、编程式导航
    • 定义别名 alias
    • router-link 与 定义路由名称
    • 编程式导航 router.push()
  • 5. 嵌套路由 children
  • 6. 重定向 redirect
  • 7. 全局前置守卫

官方文档-> Vue Router官方文档

1. 安装与使用(Vue3)

安装

npm install vue-router@4yarn add vue-router@4
版本4适用于Vue3,Vue2请使用版本3

使用

  • 文件结构:

在这里插入图片描述

  • @/router/index.js:
import { createRouter, createWebHistory } from "vue-router";const routes = [{path: "/",component: ()=> import('@/views/index.vue'),name: 'index',meta: { title: '首页', icon: '', keepAlive: true }}
]const router = createRouter({history: createWebHistory(),routes,
})export default router;
  • @/main.js:
import { createApp } from 'vue'
import App from './App.vue'
import router from './router/index.js'const app = createApp(App)
app.use(router)
app.mount('#app')
  • @/App.vue:
<template><router-view v-if="!$route.meta.keepAlive" /><router-view  v-slot="{ Component }" v-if="$route.meta.keepAlive"><keep-alive><component :is="Component"></component></keep-alive></router-view><!-- 以下为版本3可支持写法 --><!-- <keep-alive><router-view v-if="$route.meta.keepAlive"></router-view></keep-alive> -->
</template><script setup>
</script>

2. 配置路径别名@和VSCode路径提示(了解)

(作为了解,新建Vue3项目时已配有)

  • 配置路径别名@在代码编写编写中代替 /src
    在这里插入图片描述
  • VSCode路径提示
    在这里插入图片描述

3. 使用查询字符串或路径传参

query

<template><h1>我是首页</h1><p>{{ route.query }}</p>
</template>
<script setup>
import { useRouter, useRoute } from 'vue-router'const router = useRouter();
const route = useRoute();
</script>

(选项式API用this.$route.query
在这里插入图片描述

动态路由 与 params

@/router/index.js:

import { createRouter, createWebHistory } from "vue-router";const routes = [{path: "/",component: ()=> import('@/views/index.vue'),name: 'index',meta: { title: '首页', icon: '', keepAlive: true }},{path: "/user/:id/username/:username",component: ()=> import('@/views/user.vue'),name: 'user',meta: { title: '个人主页', icon: '', keepAlive: true }}
]const router = createRouter({history: createWebHistory(),routes,
})export default router;

:[parma参数名]?表示该参数可不填)

<template><h1>我是个人主页</h1><p>{{ route.params }}</p>
</template>
<script setup>
import { useRouter, useRoute } from 'vue-router'const router = useRouter();
const route = useRoute();
</script>

(选项式API用this.$route.params
在这里插入图片描述

4. router-link、定义别名、定义路由名称、编程式导航

定义别名 alias

alias

import { createRouter, createWebHistory } from "vue-router";const routes = [{path: "/",// alias: "/home", // 单个alias: ["/home", "/index"], // 多个component: ()=> import('@/views/index.vue'),name: 'index',meta: { title: '首页', icon: '', keepAlive: true }},{path: "/user/:id?/username/:username",component: ()=> import('@/views/user.vue'),name: 'user',meta: { title: '个人主页', icon: '', keepAlive: true }}
]const router = createRouter({history: createWebHistory(),routes,
})

路径//home/index 是同一页面

router-link 与 定义路由名称

  <router-link to="/home?title=标题&id=1006">查询字符串传参</router-link><router-link :to="{path: '/home', query: { title : '标题', id: 1006 }}">查询字符串传参 - 动态属性绑定</router-link><router-link to="/user/1006/username/hsy">路径传参</router-link><router-link :to="{name: 'user', params: { id : 1006, username: 'hsy' }}">路径传参 - 动态属性绑定</router-link>

编程式导航 router.push()

<template><button @click="goto(1)">跳转首页</button><button @click="goto(2)">跳转个人主页</button>
</template>
<script setup>
import { useRouter, useRoute } from 'vue-router'const router = useRouter();
const route = useRoute();function goto(type = 1) {if(type === 1) {// router.push('/home?title=标题&id=1006')router.push({path: '/home', query: { title : '标题', id: 1006 }});} else {// router.push('/user/1006/username/hsy')router.push({name: 'user', params: { id : 1006, username: 'hsy' }});}
}
</script>

5. 嵌套路由 children

  • @/router/index.js:
import { createRouter, createWebHistory } from "vue-router";const routes = [{path: "/",// alias: "/home", // 单个alias: ["/home", "/index"], // 多个component: ()=> import('@/views/index.vue'),name: 'index',meta: { title: '首页', icon: '', keepAlive: true }},{path: "/user/:id?/username/:username",component: ()=> import('@/views/user.vue'),name: 'user',meta: { title: '个人主页', icon: '', keepAlive: true }},{path: "/vip",component: ()=> import('@/views/vip/index.vue'),name: 'vip',meta: { title: '会员页', icon: '', keepAlive: true },children: [{path: 'info',component: ()=> import('@/views/vip/info.vue'),}]}
]const router = createRouter({history: createWebHistory(),routes,
})export default router;
  • @/views/vip/index.vue
<template><h1>会员页</h1>-----------------------------<router-view></router-view>-----------------------------
</template>

6. 重定向 redirect

import { createRouter, createWebHistory } from "vue-router";const routes = [{path: "/",// alias: "/home", // 单个alias: ["/home", "/index"], // 多个component: ()=> import('@/views/index.vue'),name: 'index',meta: { title: '首页', icon: '', keepAlive: true }},{path: "/user/:id?/username/:username",component: ()=> import('@/views/user.vue'),name: 'user',meta: { title: '个人主页', icon: '', keepAlive: true }},{path: "/vip",component: ()=> import('@/views/vip/index.vue'),name: 'vip',meta: { title: '会员页', icon: '', keepAlive: true },children: [{path: 'info',component: ()=> import('@/views/vip/info.vue'),}]},{path: '/myhome',// redirect : '/',// redirect : '/?title=标题&id=1006',// redirect : {//   path: '/',//   query: {//     title: '标题',//     id: 1006,//   }// },// redirect : '/user/1006/username/hsy',redirect : {name: 'user',params: {username: 'hsy',id: 1006,}},}
]const router = createRouter({history: createWebHistory(),routes,
})export default router;

7. 全局前置守卫

main.js:

import { createApp } from 'vue'
import App from './App.vue'
import router from './router/index.js'const app = createApp(App)
app.use(router)
//  路由前置守卫
router.beforeEach((to, from, next) => {console.log('即将进入的路由的信息to:',to);console.log('当前即将离开的路由的信息from:',from);if(to.name === "user") {// next(false); // 拦截不跳转next({path: '/home'}); // 拦截跳转到首页} else {next(); // 不拦截}
})
app.mount('#app')

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/828874.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

李沐66_使用注意力机制的seq2seq——自学笔记

加入注意力 1.编码器对每次词的输出作为key和value 2.解码器RNN对上一个词的输出是query 3.注意力的输出和下一个词的词嵌入合并进入RNN 一个带有Bahdanau注意力的循环神经网络编码器-解码器模型 总结 1.seq2seq通过隐状态在编码器和解码器中传递信息 2.注意力机制可以根…

ELK技术介绍:背景、功能及应用场景全面解析

一、ELK概述 ELK是由Elasticsearch、Logstash和Kibana三个开源软件组成的日志管理解决方案&#xff0c;这一组合在近年来得到了广泛的关注和应用。ELK的出现&#xff0c;源于大数据和云计算技术的快速发展&#xff0c;以及对高效日志管理的迫切需求。 随着企业信息化程度…

【10-10-10旁观思维】项目管理必会的思维分析工具 08(送模板~)

&#x1f468;‍&#x1f4bb;&#x1f469;‍&#x1f4bb;面对一个决策或选择&#xff0c;当你犹豫不决时&#xff0c;可以想一下 ⏰10分钟后&#xff0c;自己是怎么看待自己现在的决策&#xff0c;依然保持一致亦或会后悔&#xff1b; ⏰10个月后&#xff0c;你又会如何思…

Javascript 插值搜索与二分搜索

插值搜索和二分搜索都是在有序数组中查找目标元素的算法。它们之间的核心区别在于确定中间元素的方式。 1、二分搜索&#xff08;Binary Search&#xff09;&#xff1a;二分搜索是一种通过将目标值与数组中间元素进行比较&#xff0c;然后根据比较结果缩小搜索范围的算…

Docker资源管理-数据管理

一、CPU 资源控制&#xff1a; 1.cgroups&#xff1a; cgroups&#xff0c;是一个非常强大的linux内核工具&#xff0c;他不仅可以限制被 namespace 隔离起来的资源&#xff0c; 还可以为资源设置权重、计算使用量、操控进程启停等等。 所以 cgroups&#xff08;Control grou…

深度剖析SSD掉电保护机制-1

随着固态硬盘&#xff08;Solid State Drives, SSD&#xff09;在数据中心、企业存储、个人计算设备等领域广泛应用&#xff0c;其数据安全性与可靠性成为至关重要的考量因素。其中&#xff0c;应对突发电源故障导致的数据丢失风险的掉电保护&#xff08;Power Loss Protection…

MA-Chitosan MA甲基丙烯酸修饰羧甲基壳聚糖 MA-Chitosan

MA-Chitosan MA甲基丙烯酸修饰羧甲基壳聚糖 MA-Chitosan、 【中文名称】甲基丙烯酸化羧甲基壳聚糖 【英文名称】Chitosan-MA 【结 构】 【纯 度】95%以上 【保 存】-20℃ 【规 格】10mg,500mg,1g,5g,10g 【产品特性】 Chitosan-MA&#xff08;壳聚糖-甲基丙烯酸…

Verilog基础语法——parameter、localparam与`define

Verilog基础语法——parameter、localparam与define 写在前面一、localparam二、parameter三、define写在最后 写在前面 在使用Verilog编写RTL代码时&#xff0c;如果需要定义一个常量&#xff0c;可以使用define、parameter和localparam三种进行定义与赋值。 一、localparam …

大模型都在用的:旋转位置编码

写在前面 这篇文章提到了绝对位置编码和相对位置编码&#xff0c;但是他们都有局限性&#xff0c;比如绝对位置编码不能直接表征token的相对位置关系&#xff1b;相对位置编码过于复杂&#xff0c;影响效率。于是诞生了一种用绝对位置编码的方式实现相对位置编码的编码方式——…

机器学习day1

一、人工智能三大概念 人工智能三大概念 人工智能&#xff08;AI&#xff09;、机器学习&#xff08;ML&#xff09;和深度学习&#xff08;DL&#xff09; 人工智能&#xff1a;人工智能是研究计算代理的合成和分析的领域。人工智能是使用计算机来模拟&#xff0c;而不是人类…

关于Android中的限定符

很多对于Android不了解或是刚接触Android的初学者来说&#xff0c;对于Android开发中出现的例如layout-large或者drawable-xxhdpi这样的文件夹赶到困惑&#xff0c;这这文件夹到底有什么用&#xff1f;什么时候用&#xff1f;这里简单的说一下。 其实&#xff0c;在上面例子中&…

基于OpenCV的人脸签到系统

效果图 目录文件 camerathread.h 功能实现全写在.h里了 class CameraThread : public QThread {Q_OBJECT public:CameraThread(){//打开序号为0的摄像头m_cap.open(0);if (!m_cap.isOpened()) {qDebug() << "Error: Cannot open camera";}//判断是否有文件,人脸…

iframe实现pdf预览,并使用pdf.js修改内嵌标题,解决乱码问题

项目中遇到文件预览功能,并且需要可以打印文件.下插件对于内网来说有点麻烦,正好iframe预览比较简单,且自带下载打印等功能按钮. 问题在于左上方的文件名乱码,网上找了一圈没有看到解决的,要么就是要收费要会员(ztmgs),要么直接说这东西改不了. 使用: 1.引入 PDF.js 库&…

Spring Boot集成Redisson实现延迟队列

项目场景&#xff1a; 在电商、支付等领域&#xff0c;往往会有这样的场景&#xff0c;用户下单后放弃支付了&#xff0c;那这笔订单会在指定的时间段后进行关闭操作&#xff0c;细心的你一定发现了像某宝、某东都有这样的逻辑&#xff0c;而且时间很准确&#xff0c;误差在1s内…

与AI对话:探索最佳国内可用的ChatGPT网站

与AI对话&#xff1a;探索最佳国内可用的ChatGPT网站 &#x1f310; 链接&#xff1a; GPTGod 点击可注册 &#x1f3f7;️ 标签&#xff1a; GPT-4 支持API 支持绘图 Claude &#x1f4dd; 简介&#xff1a;GPTGod 是一个功能全面的平台&#xff0c;提供GPT-4的强大功能&…

JavaEE——Spring Boot + jwt

目录 什么是Spring Boot jwt&#xff1f; 如何实现Spring Boot jwt&#xff1a; 1. 添加依赖 2、创建JWT工具类 3. 定义认证逻辑 4. 添加过滤器 5、 http请求测试 什么是Spring Boot jwt&#xff1f; Spring Boot和JWT&#xff08;JSON Web Token&#xff09;是一对常…

苍穹外卖学习

并不包含全部视频内容&#xff0c;大部分都按照操作文档来手搓代码&#xff0c;资料&#xff0c;代码都上传git。 〇、实际代码 0.1 Result封装 package com.sky.result;import lombok.Data;import java.io.Serializable;/*** 后端统一返回结果* param <T>*/ Data pub…

软考 系统架构设计师系列知识点之软件可靠性基础知识(5)

接前一篇文章&#xff1a;软考 系统架构设计师系列知识点之软件可靠性基础知识&#xff08;4&#xff09; 所属章节&#xff1a; 第9章. 软件可靠性基础知识 第1节 软件可靠性基本概念 9.1.3 可靠性目标 前文定量分析软件的可靠性时&#xff0c;使用失效强度来表示软件缺陷对…

20232937文兆宇 2023-2024-2 《网络攻防实践》实践七报告

20232937文兆宇 2023-2024-2 《网络攻防实践》实践七报告 1.实践内容 &#xff08;1&#xff09;使用Metasploit进行Linux远程渗透攻击 任务&#xff1a;使用Metasploit渗透测试软件&#xff0c;攻击Linux靶机上的Samba服务Usermap_script安全漏洞&#xff0c;获取目标Linux…

机器学习day3

一、距离度量 1.欧氏距离 2.曼哈顿距离 3.切比雪夫距离 4.闵可夫斯基距离 二、特征与处理 1.数据归一化 数据归一化是一种将数据按比例缩放&#xff0c;使之落入一个小的特定区间的过程。 代码实战 运行结果 2.数据标准化 数据标准化是将数据按照其均值和标准差进行缩放的过…