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

news2024/11/20 21:37:19

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.js

Vue.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';
  }
})

作业

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7dNMKgro-1685015439818)(…/resource/md/1684926163149.png)]

2 • 配置Fitness健身项目的路由(一级路由 和 二级路由)。

3 代码练习

4 xmind

5 下节课过一眼

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

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

相关文章

Doris---数据表设计

表的基本概念 1 Row & Column 一张表包括行&#xff08;Row&#xff09;和列&#xff08;Column&#xff09;&#xff1b; Row 即用户的一行数据。Column 用于描述一行数据中不同的字段。 doris中的列分为两类&#xff1a;key列和value列 key列在doris中有两种作用&…

【Android】【Java】播放多段视频切换时出现的短暂黑屏现象处理

逻辑描述 当A视频正在播放中&#xff0c;点击A视频跳过A视频剩余内容并加载B视频 Bug描述 在切换视频时&#xff0c;显示短暂黑屏&#xff0c;如下图所示&#xff1a; 解决思路 当看到这个bug出现时&#xff0c;第一反应是第二段视频在初始化视频时有一定的延时&#xff…

关于C语言杂记7

文章目录 关于数组二级指针字符串字符串的输入与输出字符串函数1、字符数组的输入和输出&#xff1a;2、5种相关函数&#xff1a; 关于数组 char *fruits[LEN] { // 定义一个字符指针数组&#xff0c;包含LEN个元素"apple", // 初始化第1个元素为字符串"a…

【C++】unordered_map和unordered_set的使用

文章目录 前言一、unordered_map的使用及性能测试二、unordered_set的使用 1.习题练习总结 前言 unordered 系列关联式容器 &#xff1a; 在 C98 中&#xff0c; STL 提供了底层为红黑树结构的一系列关联式容器&#xff0c;在查询时效率可达到O&#xff08;logN&#xff09; &a…

SDN — Google B4 SDN WAN 网络架构

目录 文章目录 目录Google B4 SDN WAN 网络B4 网络架构物理设备层局部网络控制层全局控制层Hybrid SDN 模式Google B4 SDN WAN 网络 Google 的 WAN 有 2 张网络(Two Backbones): B2(I-Scale Network):数据中心互联 Internet(POP)的网络,用于面向 Internet 用户访问,…

大象转身只需点点鼠标,爆火 DragGAN 原理浅析

出品人&#xff1a;Towhee 技术团队 作者&#xff1a;张晨 DragGAN介绍 合成满足用户需求的视觉内容往往需要对生成对象的姿势、形状、表情和布局进行灵活和精确的控制。 现有方法通过手动注释的训练数据或先前的 3D 模型获得生成对抗网络 (GAN) 的可控性&#xff0c;这通常缺乏…

保姆级教程:手把手教你拿下雅思写作7分

在留学路上&#xff0c;雅思考试是绕不开的一道坎。然而&#xff0c;众所周知&#xff0c;雅思学习热度高&#xff0c;学习难度大&#xff0c;而且很多人找不到合适的学习方法。在这里&#xff0c;我们以雅思写作中的大作文为例&#xff0c;从大作文的结构拆解、学习的任务拆分…

SSM编程---Day 02

目录 一、核心配置文件 二、junit介绍 三、自定义java注解 四、自定义注解 五、添加log4j的支持 六、sql映射文件的介绍 一、核心配置文件 1、核心配置文件中需要注意顺序 2、根节点 <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN"…

数据结构-最小生成树Prim算法的实现

目录 一、前言 二、最小生成树 三、Prim算法 四、Prim算法的实现 一、前言 在计算机科学中&#xff0c;数据结构是一种组织和存储数据的方式&#xff0c;以便于访问和修改。数据结构是计算机科学的基础&#xff0c;它是算法的基础。在数据结构中&#xff0c;最小生成树是一…

Python调用腾讯云函数传递json数据

前言 有些时候有一些公共的方法&#xff0c;需要放在服务器上&#xff0c;在不同的电脑上使用。但是我们有没有自己的服务器&#xff0c;所以考虑将公共的方法放在腾讯云、华为云、阿里云、百度云等云平台上&#xff0c;方便在不同的电脑上复用。 我们这里使用的是腾讯云&#…

AMD Software Adrenalin Edition 23.5.1驱动发布,快速获取驱动

AMD新驱动赶在五月天发布&#xff01;AMD Software Adrenalin Edition 23.5.1驱动 &#xff0c;为部分游戏带来支持&#xff0c;以及为重要的软件带来修复。驱动人生带大家一览AMD WHQL 23.5.1驱动的优化内容。 游戏方面&#xff0c;AMD WHQL 23.5.1主要为游戏《指环王&#x…

详解MVCC相关知识点

前言&#xff1a;学习前&#xff0c;先叙述mysql相关基础知识&#xff0c;一步步了解mysql底层机制。 1.Mysql的隔离级别&#xff1a; 数据库事务的隔离级别有4个&#xff0c;由低到高依次为Read uncommitted 、Read committed、Repeatable read 、Serializable &#xff0c;这…

23种设计模式之观察者模式(Observer Pattern)

前言&#xff1a;大家好&#xff0c;我是小威&#xff0c;24届毕业生&#xff0c;在一家满意的公司实习。本篇文章将23种设计模式中的观察者模式&#xff0c;此篇文章为一天学习一个设计模式系列文章&#xff0c;后面会分享其他模式知识。 如果文章有什么需要改进的地方还请大佬…

计算机视觉与OpenCV算法学习内容总结,太详细了!

计算机视觉是一项基于数字图像和视频处理的前沿技术&#xff0c;在人工智能领域中得到了广泛应用。而OpenCV&#xff08;开源计算机视觉库&#xff09;是一款以C语言为主的跨平台计算机视觉库&#xff0c;被广泛认可为业界最优秀的计算机视觉库之一。 相比于传统的图像处理技术…

【selenium自动化测试入门】 python unittest单元测试框架

unittest又名PyUnit&#xff0c; Python单元测试框架&#xff08;The Python unit testing framework&#xff09;&#xff0c;简称为PyUnit。自从 Python 2.1 版本后&#xff0c;PyUnit成为 Python标准库的一部分。 为什么需要使用unittest单元测试框架&#xff1f; 当我们写…

老油条感叹:现在00后真的太卷了....

最近内卷严重&#xff0c;各种跳槽裁员&#xff0c;相信很多小伙伴也在准备今年的金九银十的面试计划。 在此展示一套学习笔记 / 面试手册&#xff0c;年后跳槽的朋友可以好好刷一刷&#xff0c;还是挺有必要的&#xff0c;它几乎涵盖了所有的软件测试技术栈&#xff0c;非常珍…

预训练模型 ---- BERT架构

目录 什么是BERT BERT的架构 BERT的预训练任务 小节总结 BERT的特点 BERT和GPT的区别 笔记参考&#xff1a;【2023最新&#xff01;4个小时带你重新认识【BERTtransformer】&#xff0c;详解self-attention&#xff0c;翻遍全网找不到比它更详细的了&#xff01;&#xf…

工作记录:在线 word - 列表

需求&#xff1a;上传 word 文档&#xff0c;在页面的富文本编辑器中展示、编辑后&#xff0c;再导出成 word 格式。 我负责开发列表功能 为什么不用 ul 一开始想用<ul> <li> 去实现列表&#xff0c;但随即发现一些问题&#xff1a; 问题一&#xff1a;word 中的…

知乎+chatgpt炸了!撸点小钱~

大家好&#xff0c;我是五竹。 之前分享了一下&#xff0c;朋友圈的好友如何复制我的玩法利用chatgpt赚点小钱的实战&#xff1a;TMD&#xff0c;被人偷窥了一个月&#xff01; 紧接着我自己最近也在知乎小赚了一笔&#xff01;我以为在知乎上那篇文章的热点就消退了&#xff0…

字节25K就面试这些?简直惊呆我了...

互联网行业竞争是一年比一年严峻&#xff0c;作为软件测试工程师的我们唯有不停的学习&#xff0c;不断提升自己才能保证自己的核心竞争力从而拿到更好的薪水&#xff0c;进入心仪的企业&#xff08;阿里&#xff0c;字节跳动&#xff0c;腾讯&#xff0c;美团&#xff09; 话不…