【无标题】 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.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';
  }
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值