当前位置: 首页 > news >正文

【无标题】 Vue 路由库Router 【重点】 - 安装 - 基本使用 - 路由配置 - 路由模式 - 路由传递参数 - 路由内置对象 - 路由守卫

0.0 课程介绍

  • Vue 路由库Router 【重点】

    • 安装
    • 基本使用
    • 路由配置
    • 路由模式
    • 路由传递参数
    • 路由内置对象
    • 路由守卫
  • Vue的内置API 【掌握】

    • ref

    • Vue.set

    • Vue.nextTick

    • Vue.filter

    • Vue.component

    • Vue.use

    • Vue.directive

1.0 Vue的路由Router 【重点】

1.1 路由作用

进行页面的跳转(相当于a标签),Vue是SPA单页面应用,他的页面跳转必须使用Vue-Router路由进行实现

1.2 路由的安装

vue create 项目名 创建一个带有Vue路由的项目

1.3 路由的使用

一级路由配置

  • 1 建(建大页面)
  • 2 配 (配置路由选项,一一对应)
  • 3 给出口及测试
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9hSG1kvr-1685015439810)(C:\Users\陈\AppData\Roaming\Typora\typora-user-images\1685015185815.png)]
如果你的页面需要进行路由显示,必须给出口 <router-view></router-view>,一级路由出口在App.vue页面,嵌套路由出口在父页面
路由出口:就是你页面需要渲染的位置
测试:在浏览器路径输入对应path// 配置路由列表
const routes = [{ path: '/', redirect: '/discover' }, // redirect: 重定向指定的路由(一级路由)// 配置一级路由{ path: '/discover', component: DiscoverView },{ path: '/my', component: MyView },{ path: '/friend', component: FriendView },
]
  • 4 配置导航
    在你需要出现的页面设置你的出口
    如果 你需要跳转 就要用 触发事件来跳转
    这是首页的出口设置
    这是你需要在首页出口设置的页面
<router-link to="/discover">发现音乐</router-link>
<router-link to="/my">我的音乐</router-link>
<router-link to="/friend">关注音乐</router-link>

嵌套路由配置

  • 1 建 (建大页面)
  • 2 配 (配置路由选项,一一对应)
  • 3 给出口及测试
嵌套路由的出口在父页面 <router-view></router-view>{path: '/discover', component: DiscoverView,redirect: '/discover/toplist',  // redirect: 重定向指定的路由(嵌套路由)// 配置嵌套路由children: [{ path: '/discover/recommend', component: RecommendView },{ path: '/discover/toplist', component: ToplistView },{ path: '/discover/playlist', component: PlaylistView },]},
  • 4 配置导航
  <div class="discover"><!-- 嵌套路由的出口在父页面 --><router-link to="/discover/recommend">推荐</router-link><router-link to="/discover/toplist">排行榜</router-link><router-link to="/discover/playlist">歌单</router-link><!-- 嵌套路由的出口 --><router-view></router-view></div>

1.4 路由的模式 【重点】

【面试题】

  • hash模式 :地址栏带#, 底层实现的是用 onhashchange的一个方法

  • history模式 : 地址栏不带#,底层实现是用的h5的 pushState 方法

    区别:

    [1] : 地址栏一个带#,一个不带#

    [2] : 底层实现的原理不一样

    [3] : hash模式根history模式在开发中没有任何区别,但是在打包后的代码hash模式没有问题,history模式会存在刷新后页面丢失情况

    #解决办法: 只能让后端或者运维,对nginx代理服务器进行相应重定向的配置

1.5 路由的传参 【掌握】

  • query传参
// 路由提供了一个跳转的方法 this.$router.push('/路径')
// query配置项
1、路由跳转
this.$router.push({path:'/路径',query:{键名:键值,键名1:键值1,}
})
2、获取参数
this.$route.query特点:	1、页面刷新参数依旧存储2、不能直接传递引用类型(可以用JSON.stringify 转成字符串【不推荐】)
  • params传参
// 路由提供了一个跳转的方法 this.$router.push('/路径')
// params配置项
1、路由跳转
this.$router.push({name:'路由名',params:{// 并且可以携带引用类型键名:键值,键名1:键值1,}
})
2、获取参数
this.$route.params特点:1、页面可以携带引用类型2、刷新页面数据丢失(将刷新按钮禁用或者去除)
  • 动态路径传参
// 路由提供了一个跳转的方法 this.$router.push('/路径')
1、路由配置项中进行路径动态传参配置
{ path: '/my/:变量名', component: MyView },
2、路由跳转
this.$router.push({path:'/my/传入的值'
})
3、获取参数
this.$route.params特点: 1、刷新页面后不会丢失数据2、动态路径必须携带参数

1.6 路由的两个内置对象【掌握】

  • $router

路由实例对象,他主要提供一些页面跳转的方法(他其实就等 === VueRouter)

​ push

​ go

replace

  • $route

路由信息对象,他主要提供当前页面的参数信息

params

query

path

1.7 路由守卫【理解】

全局前置路由守卫,监听路由变换,判断是有权限

router.beforeEach((to,from,next)=>{// to  你要去往哪里// from 你从哪里来// next 是个函数,如果直接调用就可以前往,如果传入路径,就前往指定页面
})router.beforeEach((to, from, next) => {// 如果我跳转目标是我的,那我就让你重定向关注if (to.path == '/discover/recommend') {next({ path: '/discover/playlist' })} else {next()}// const token = localStorage.getItem('token123')// if (!token) {//   next({ path: '/login' })// } else {//   next()// }
})

2.0 Vue的内置API【掌握】

2.1 ref

作用:用于获取Dom节点,相当于元素选择器,如果你获取的是子组件,相当于获取到自组件的实例对象

<template><div>#dom<span ref="ref的值1">dom节点</span>#子组件<son ref="ref的值2"></son></div>
</template><script>
export default {methods:{init(){this.$refs.ref的值1  #DOM节点this.$refs.ref的值2  #子组件的实例对象}}
}
</script>
定义ref的值: 在父页面的子组件(或dom)标签上定义属性ref=“ref的值”
获取ref的值: 在js中通过this.$refs.ref的值 来获取子组件实例(或dom节点) 

2.2 Vue.set

他可以帮助我们重新挟持【绑架】数据,让数据具备响应式

理论【面试题】:因为Vue底层会对data里进行挟持,当初始状态对象没有这个属性,后期添加的属性没有被挟持,不具备响应式,通过Vue.set方法让数据重新挟持

import Vue from 'vue'
Vue.set(需要挟持的对象, "属性", "修改的值");this.$set(需要挟持的对象, "属性", "修改的值")

数组怎么改?

解决方法:数组的变更方法,这是被Vue重写的方法,可以让数组里的数据修改时也具备响应式

push()
pop()
shift()
unshift()
splice()
sort()
reverse()以上方法已经升级啦

2.3 Vue.nextTick

他是一个回调函数,帮你解决异步的问题,在下一次页面节点更新完毕后触发

import Vue from 'vue'
Vue.nextTick(()=>{// 下一次页面节点更新完毕后触发
})this.$nextTick(()=>{// 下一次页面节点更新完毕后触发
})created() {// 本身created是拿不到dom节点console.log(document.querySelector("#msg"));// 但是nextTick是下一次dom更新后触发 ,就相当于mounted时触发回调函数Vue.nextTick(() => {console.log(document.querySelector("#msg"));});this.$nextTick(() => {console.log(document.querySelector("#msg"));});}

2.4 Vue.filter

全局过滤器,注册的全局过滤器可以在任何页面使用

#main.jsVue.filter('过滤器的名字',(参数)=>{// 一堆格式处理的逻辑return ’过滤后的结果‘
})

2.5 Vue.component

注册全局组件

// 全局组件
Vue.component('Counter', Counter)

2.6 Vue.use

使用插件,当插件是基于Vue.js写的,就需要use一下

import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
import App from './App.vue';// 因为ElementUI底层是基于Vue.js写的 所以需要Vue.use使用一下
Vue.use(ElementUI);

2.7 Vue.directive

自定义的指令,可以根据自身需求自己定义

Vue.directive('指令名',{// 里面有很多的配置bind #只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置。inserted #被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)})Vue.directive('overflow', {inserted: (dom, obj) => {// 截取 溢出隐藏dom.style.width = obj.value + 'px'dom.style.overflow = 'hidden'dom.style.whiteSpace = 'nowrap';dom.style.textOverflow = 'ellipsis';}
})

相关文章:

【无标题】 Vue 路由库Router 【重点】 - 安装 - 基本使用 - 路由配置 - 路由模式 - 路由传递参数 - 路由内置对象 - 路由守卫

0.0 课程介绍 Vue 路由库Router 【重点】 安装基本使用路由配置路由模式路由传递参数路由内置对象路由守卫 Vue的内置API 【掌握】 ref Vue.set Vue.nextTick Vue.filter Vue.component Vue.use Vue.directive 1.0 Vue的路由Router 【重点】 1.1 路由作用 进行页面…...

RocksDB笔记 -- 整体架构

RocksDB是由Facebook开发的存储引擎, 它最初的目标是用于快速存储, 特别是Flash存储. 一个基于C开发keys-values存储引擎库. 整体架构 RocksDB由这三个基本结构组成: memtable, sstfile 和 logfile. 其中: memtable是一个内存数据结构, 新的写入会插入到memtable中, 同时可选…...

设计模式之单例模式入门介绍

一、设计模式概念 设计模式是被广泛使用的软件开发中的一种解决方案&#xff0c;它提供了一套被验证过的、可重用的设计思想&#xff0c;帮助开发人员更加高效地开发出可维护、易扩展的软件系统。 设计模式可以分为三类&#xff1a;创建型模式、结构型模式和行为型模式。 1.1…...

RHCE 作业三

1.基于域名访问网站 [rootserver ~]# setenforce 0 [rootserver ~]# systemctl stop firewalld [rootserver ~]# systemctl disable firewalld [rootserver ~]# yum install httpd -y [rootserver ~]# systemctl start httpd [rootserver ~]# syst…...

90.qt qml-Table表格组件(支持表头表尾固定/自定义颜色/自定义操作按钮/插入排序)

众所周知,qml table在目前版本还很废,qt5的table完全就没法用,在之前章节就写过: 88.qt qml-TableView学习(一)_诺谦的博客-CSDN博客 所以本章便参考VUE-Element的Table外观组件实现一个可排序可操作的Table组件. 1.组件介绍 GIF如下所示: 排序支持数字和字符串排序。 …...

android 12.0SystemUI屏蔽某个app的通知

1.概述 在12.0的产品开发中,对于系统的通知部分,要求根据app包名来过滤掉一部分通知,就是在接收到系统通知时,根据包名判断是否需要接收通知的功能,首选要分析通知流程,然后实现功能 2.SystemUI屏蔽某个app的通知相关代码 frameworks\base\packages\SystemUI\src\com\…...

注意力机制(一)SE模块(Squeeze-and-Excitation Networks)论文总结和代码实现

Squeeze-and-Excitation Networks&#xff08;压缩和激励网络&#xff09; 论文地址&#xff1a;Squeeze-and-Excitation Networks 论文中文版&#xff1a;Squeeze-and-Excitation Networks_中文版 代码地址&#xff1a;GitHub - hujie-frank/SENet: Squeeze-and-Excitation Ne…...

L2-001 紧急救援(dijkstra算法练习)

作为一个城市的应急救援队伍的负责人&#xff0c;你有一张特殊的全国地图。在地图上显示有多个分散的城市和一些连接城市的快速道路。每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上。当其他城市有紧急求助电话给你的时候&#xff0c;你的任务是带领你的…...

redis问题汇总

redis的优点 读写性能优异。十万/s的量级&#xff1b; 支持数据持久化。AOF,RDB 支持丰富的数据类型&#xff1b; 支持集群&#xff0c;可以实现主从复制&#xff0c;哨兵机制迁移&#xff0c;扩容等 缺点&#xff1a; 因为是基于内存的&#xff0c;所以虽然redis本身有key过期…...

调用华为API实现情感分析

作者介绍 王新华&#xff0c;男&#xff0c;西安工程大学电子信息学院&#xff0c;2022级研究生 研究方向&#xff1a;人工智能与模式识别 电子邮件&#xff1a;996514274qq.com 魏小双&#xff0c;女&#xff0c;西安工程大学电子信息学院&#xff0c;2022级研究生 研究方向…...

C# 静态构造函数

静态构造函数用于初始化任何静态数据&#xff0c;或执行仅需要执行一次的特定操作。在创建第一个实例或引用任何静态成员之前&#xff0c;将自动调用它。 静态构造函数是在构造函数方法前面添加了static关键字之后形成的&#xff0c;并且没有修饰符(public,private),没有参数。…...

【C++】哈希表特性总结及unordered_map和unordered_set的模拟实现

✍作者&#xff1a;阿润菜菜 &#x1f4d6;专栏&#xff1a;C 文章目录 前言一、哈希表的特性 - 哈希函数和哈希冲突1 哈希函数2. 哈希冲突 二、闭散列的实现 -- 开放地址法1. 定义数据结构2.insert()3.Find()4. Erase()5.仿函数处理key值不能取模无法映射 --- BKDRHash 三、开…...

Qt在Linux内核中的应用及解析(qtlinux内核)

Qt是跨平台开发的一种工具&#xff0c;尤其适合在Linux内核中的应用开发中使用。Qt能够让开发者在Linux桌面上开发出强大的图形化应用程序&#xff0c;为Linux系统用户提供更加人性化、实用、智能化的服务。本文将从Qt在Linux内核中的应用场景、应用程序开发中的具体使用、以及…...

Xpdf 阅读器源码编译后查看文件中文乱码问题解决

经查阅&#xff0c;是由于缺少中文字体包&#xff1a; 第一步&#xff1a;下载所需要的字体包 下载https://dl.xpdfreader.com/xpdf-t1fonts.tar.gz 包含下载中文字体包&#xff08;非嵌入字体&#xff09; http://ftp.gnu.org/gnu/non-gnu/chinese-fonts-truetype/gkai00mp…...

Java - AQS-CountDownLatch实现类(二)

前言 在Java中&#xff0c;AbstractQueuedSynchronizer&#xff08;简称AQS&#xff09;是一个用于实现同步器的抽象类&#xff0c;它为实现各种类型的同步器&#xff08;如锁、信号量等&#xff09;提供了基本的框架。AQS通过一个双向队列&#xff08;等待队列&#xff09;和…...

rsut基础

这篇文章是实战性质的&#xff0c;也就是说原理部分较少&#xff0c;属于经验总结&#xff0c;rust对于模块的例子太少了。rust特性比较多&#xff08;悲&#xff09;&#xff0c;本文的内容可能只是一部分&#xff0c;实现方式也不一定是这一种。 关于 rust 模块的相关内容&a…...

高压放大器和示波器的关系是什么

高压放大器和示波器是电子工程领域中常见的两种设备&#xff0c;它们在实际的电路设计、测试和分析中都扮演着重要的角色。下面安泰电子将从定义、功能、应用场景等方面为您介绍高压放大器和示波器的关系。 图&#xff1a;ATA-7000系列高压放大器 一、高压放大器的定义及功能 高…...

5个超实用视频素材网站,免费下载~

推荐几个高清无水印的视频素材网站&#xff0c;重点是可以免费下载使用&#xff0c;建议收藏&#xff01; 菜鸟图库 https://www.sucai999.com/video.html?vNTYxMjky 可以称之为最大素材库&#xff0c;在这里你可以找到设计、办公、图片、视频、音频等各种素材。视频素材就有…...

【NLP模型】文本建模(1)(BoW、N-gram、tf-idf)

目录 一、说明 二、BoW模型产生发展 2.1 产生和历史 2.2 原理介绍 三、具体实现...

Java——网络编程套接字

目录 一、网络编程基础 1.1 为什么需要网络编程&#xff1f;——丰富的网络资源 二、什么是网络编程? 三、网络编程中的基本概念 3.2 请求和响应 3.3 客户端和服务端 常见的客户端服务端模型 四、Socket套接字 五、通信模型 5.1 Java数据报套接字通信模型 5.2 Java流…...

Spring Boot+Neo4j知识图谱实战:3步搭建智能关系网络!

一、引言 在数据驱动的背景下&#xff0c;知识图谱凭借其高效的信息组织能力&#xff0c;正逐步成为各行业应用的关键技术。本文聚焦 Spring Boot与Neo4j图数据库的技术结合&#xff0c;探讨知识图谱开发的实现细节&#xff0c;帮助读者掌握该技术栈在实际项目中的落地方法。 …...

MySQL中【正则表达式】用法

MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现&#xff08;两者等价&#xff09;&#xff0c;用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例&#xff1a; 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...

高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数

高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?

在工业自动化持续演进的今天&#xff0c;通信网络的角色正变得愈发关键。 2025年6月6日&#xff0c;为期三天的华南国际工业博览会在深圳国际会展中心&#xff08;宝安&#xff09;圆满落幕。作为国内工业通信领域的技术型企业&#xff0c;光路科技&#xff08;Fiberroad&…...

起重机起升机构的安全装置有哪些?

起重机起升机构的安全装置是保障吊装作业安全的关键部件&#xff0c;主要用于防止超载、失控、断绳等危险情况。以下是常见的安全装置及其功能和原理&#xff1a; 一、超载保护装置&#xff08;核心安全装置&#xff09; 1. 起重量限制器 功能&#xff1a;实时监测起升载荷&a…...

C++ 类基础:封装、继承、多态与多线程模板实现

前言 C 是一门强大的面向对象编程语言&#xff0c;而类&#xff08;Class&#xff09;作为其核心特性之一&#xff0c;是理解和使用 C 的关键。本文将深入探讨 C 类的基本特性&#xff0c;包括封装、继承和多态&#xff0c;同时讨论类中的权限控制&#xff0c;并展示如何使用类…...

C# WPF 左右布局实现学习笔记(1)

开发流程视频&#xff1a; https://www.youtube.com/watch?vCkHyDYeImjY&ab_channelC%23DesignPro Git源码&#xff1a; GitHub - CSharpDesignPro/Page-Navigation-using-MVVM: WPF - Page Navigation using MVVM 1. 新建工程 新建WPF应用&#xff08;.NET Framework) 2.…...

JUC并发编程(二)Monitor/自旋/轻量级/锁膨胀/wait/notify/锁消除

目录 一 基础 1 概念 2 卖票问题 3 转账问题 二 锁机制与优化策略 0 Monitor 1 轻量级锁 2 锁膨胀 3 自旋 4 偏向锁 5 锁消除 6 wait /notify 7 sleep与wait的对比 8 join原理 一 基础 1 概念 临界区 一段代码块内如果存在对共享资源的多线程读写操作&#xf…...

【Redis】Redis从入门到实战:全面指南

Redis从入门到实战:全面指南 一、Redis简介 Redis(Remote Dictionary Server)是一个开源的、基于内存的键值存储系统,它可以用作数据库、缓存和消息代理。由Salvatore Sanfilippo于2009年开发,因其高性能、丰富的数据结构和广泛的语言支持而广受欢迎。 Redis核心特点:…...

claude3.7高阶玩法,生成系统架构图,国内直接使用

文章目录 零、前言一、操作指南操作指导 二、提示词模板三、实战图书管理系统通过4o模型生成系统描述通过claude3.7生成系统架构图svg代码转换成图片 在线考试系统通过4o模型生成系统描述通过claude3.7生成系统架构图svg代码转换成图片 四、感受 零、前言 现在很多AI大模型可以…...