5min带你快速掌VueRouter的使用!

简介: 【8月更文挑战第18天】5min带你快速掌VueRouter的使用!

简介

vueRouter是vue开发中非常常见的一种需求!本文将带领大家在5分钟内快速回顾学习vueRouter,文章简介无废话,大家放心食用!

核心用法

路由配置与引入

安装

npm install vue-router@next

创建路由配置,在项目中创建一个路由配置文件,通常命名为router.js或者router/index.js:

import {
   
    createRouter, createWebHashHistory } from 'vue-router'
//createRouter用于创建路由的实例对象
//createWebHistory 用于指定路由的工作模式(hash模式)
import Home from '../components/Home'
 // 定义 hash 与组件之间的对应关系
const routes  = [
  {
   
   
    path: '/home',
    // 给路由命名方便访问
    name: 'myHome',
    component: Home
  },
    //404页面
    //ue3重定向写法:"/:catchAll(.*)",  "/:pathMatch(.*)",   path: "/:pathMatch(.*)*",三种写法
    path: '/:catchAll(.*)',
    name: '/404',
    component: () => import('../views/404.vue')
]

// 创建路由实例对象
const router = createRouter({
   
   
   // 指定路由工作模式
  history: createWebHashHistory(),
  routes
})
export default router

创建Vue实例,在Vue应用中,将路由配置引入并挂载到Vue实例中

import {
   
    createApp } from 'vue'
import App from './App.vue'
import router from './router'

const app = createApp(App)

app.use(router)
app.mount('#app')

使用

使用router-link

<div id="app">
  <h1>Hello App!</h1>
  <p>
    <!-- 使用 router-link 组件来导航. -->
    <!-- 通过传入 `to` 属性指定链接. -->
    <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
    <router-link to="/home">前往首页</router-link>
  </p>
  <!-- 路由出口 -->
  <!-- 路由匹配到的组件将渲染在这里 -->
  <router-view></router-view>
</div>

编程时导航

<template>
  <div>
    <button @click="navigateToHome">前往首页</button>
    <button @click="navigateToAbout">Go to About</button>
  </div>
</template>

<script setup>
import {
   
    useRouter } from 'vue-router';

const router = useRouter();

const navigateToHome = () => {
   
   
  // 字符串路径写法
  router.push("/home");

  // 路由对象写法
  // router.push({ name: 'myHome' });
};

</script>

嵌套(多级)路由

// 该文件专门用于创建整个应用的路由器
import VueRouter from 'vue-router'
//引入组件
import About from '../pages/About'
import Home from '../pages/Home'
import News from '../pages/News'
import Message from '../pages/Message'

//创建并暴露一个路由器
export default new VueRouter({
   
   
    routes:[
        {
   
   
            path:'/about',
            component:About
        },
        {
   
   
            path:'/home',
            component:Home,
            children:[
                {
   
   
                    path:'news',  //注意:news前不需要写“/”
                    component:News,
                },
                {
   
   
                    path:'message',
                    component:Message,
                }
            ]
        }
    ]
})

router-link组件的跳转方式

<router-link to="/home/message">Message</router-link>

注:访问的时候必须保持路径完成

编程时导航的写法

const jump = () => {
   
   
  // 字符串路径写法
  router.push("/home/message");;
};

路由传参(跳转)

query查询参数

查询参数是作为URL的查询字符串出现的,路由链接如:http:xxxxx/a?id=1&key=2
路由配置

const routes  = [
  {
   
       path: '/a',name: 'A', component: A},
]

跳转方式

跳转路由并携带query参数,to的字符串写法

<router-link :to="/a/?id=1">前往A组件</router-link>

跳转路由并携带query参数,to的对象写法

<router-link :to="{path:'/b',query:{id:2}}">前往B组件</router-link>

使用编程式导航写法

<script setup>
import {
   
    useRouter } from 'vue-router';
const router = useRouter();
const toA = ()=> router.push({
   
   
  path:"/a",
  query:{
   
   id:1}
})
</script>

上述三种方式跳转后,路由连接都是http:xxxxx/a?id=1

如何获取query参数

在http:xxxxx/a?id=1的路由连接中,使用router可以获取到query参数

<script setup>
import {
   
    useRouter } from 'vue-router';
const router = useRouter();
console.log(router.query.id) // 1
</script>

params动态路由

什么是动态路由

const routes = [
  {
   
    
    path: '/blog/:postId',  // :postId 是动态路由参数
    name: 'blog',
    component: BlogPost
  }
];

上述代码中,我们定义了一个路由路径/blog/:postId,其中:postId是一个动态路由参数,它表示博客文章的唯一标识。这样,当我们访问/blog/123时,123就是传递给postId参数的值,这就是动态路由。

跳转方式

跳转携带parmas参数,to的字符串写法

<router-link :to="/blog/123">跳转</router-link>

跳转携带parmas参数,to的对象写法

<router-link :to="{name:'blog',params:{postId:123}"跳转</router-link>

特别注意:路由携带params参数时,若使用to的对象写法,则不能使用path配置项,必须使用name配置

编程式导航的写法

<script setup>
import {
   
    useRouter } from 'vue-router';
const router = useRouter();
router.push({
   
    name: 'blog', params: {
   
    postId:123 } });
</script>

上述三种方式,跳转的最终路径都是http:xxxx/blog/123

如何获取parmas参数

在http:xxxx//blog/123的路由连接中,我们可以在vue组件中使用router.params获取到动态参数:

<template>
  <div>
    <--router.params.postId结果就是123-->
    <p>{
  
  { router.params.postId }}</p>
  </div>
</template>

<script setup>
import { useRouter } from 'vue-router';
const router = useRouter();
console.log(router.params.postId) // 123
</script>

路由记录

的replace属性

  • 作用:控制路由跳转时操作浏览器历史记录的模式
  • 浏览器的历史记录写入方式有两种,分别为push和replace,push是追加历史记录,replace是替换当前记录。默认值为push.

    push:浏览器记录可以前进后退。
    repalce:浏览器上一次的历史记录被覆盖

  • 如何开启repalce模式:

    <router-link  :replace = "true"   :to=".....">
    //或
    <router-link  replace   :to=".....">
    

    路由组件缓存

    1.作用:让不展示的路由组件保持挂载,不被销毁
    2.具体编码

    <keep-alive>
      <router-view></router-view>
    </keep-alive>
    
    <keep-alive include="News">
      <router-view></router-view>
    </keep-alive>
    
    <keep-alive :include="['News','title']">
      <router-view></router-view>
    </keep-alive>
    

    路由的生命周期

    路由被缓存后,如果在A路由内写了一个定时器,并在beforeDestory生命周期中写了清空定时器的函数。当切换到B组件时,由于使用缓存,该定时器是无法被清除的,因为beforeDestory不会生效。
    那么,如果在使用缓存路由组件的同时,又能在切换组件的同时清空定时器呢?
    使用路由的生命周期钩子!

    作用:路由组件所独有的两个钩子,用于捕获路由组件的激活状态

activated :路由组件被激活时触发
deactivated :路由组件失活(切换走)时触发

了解即可!使用场景比较少

全局路由守卫

路由跳转时,如果用户没有权限(localstorage中没有获取到token)时,路由跳转时应该返回登录页。这一功能可以借助路由守卫来实现。

路由守卫包括前置路由和后置路由
前置路由是初始化、页面切换时被调用,用于拦截页面的跳转操作。
路由后置守卫是离开页面时的一个操作。

基本语法:

//创建并暴露一个路由器
const router =  new VueRouter({
   
   
    routes:[
    {
   
   
      name:'xiaoxi',
      path:'message',
      component:Message,
      meta:{
   
   isAuth:true,title:'消息'},
    }
    ]
})

//全局前置路由守卫————初始化的时候被调用、每次路由切换之前被调用
router.beforeEach((to,from,next)=>{
   
   
    console.log('前置路由守卫',to,from)
    if(to.meta.isAuth){
   
    //判断是否需要鉴权
        if(localStorage.getItem('school')==='atguigu'){
   
   
            next()
        }else{
   
   
            alert('学校名不对,无权限查看!')
        }
    }else{
   
   
        next()
    }
})

//全局后置路由守卫————初始化的时候被调用、每次路由切换之后被调用
router.afterEach((to,from)=>{
   
   
    console.log('后置路由守卫',to,from)
    document.title = to.meta.title || '硅谷系统'//修改网页标题
})

export default router

前置路由接受三个参数,后置路由只是接受to、form参数

to、form和next中间件

to和form都是一个对象,里面包括了路由名name属性、路由前往或离开的路径path、query及parmas参数已经路由元信息meta(用户在routes中自定义的数据)
image.png
next是一个函数,next()表示放行拦截。

相关文章
|
5月前
|
前端开发
【掰开揉碎】React Router——React应用导航(二)
【掰开揉碎】React Router——React应用导航(二)
|
5月前
|
资源调度 前端开发 网络架构
【掰开揉碎】React Router——React应用导航(一)
【掰开揉碎】React Router——React应用导航(一)
|
前端开发
前端项目实战壹佰贰拾贰react-admin+material ui-react-admin之SimpleList中设置SimpleListConfigurable
前端项目实战壹佰贰拾贰react-admin+material ui-react-admin之SimpleList中设置SimpleListConfigurable
43 0
|
前端开发
前端项目实战壹佰贰拾捌react-admin+material ui-react-admin之SavedQueriesList之使用
前端项目实战壹佰贰拾捌react-admin+material ui-react-admin之SavedQueriesList之使用
40 0
|
JavaScript
vue3计算薪资的方法
vue3计算薪资的方法
|
5月前
|
JavaScript 前端开发
使用styled-components控制主题切换(有手就行)
使用styled-components控制主题切换(有手就行)
124 0
|
前端开发
前端项目实战壹佰贰拾玖react-admin+material ui-react-admin之Pagination之使用
前端项目实战壹佰贰拾玖react-admin+material ui-react-admin之Pagination之使用
74 0
|
前端开发
前端项目实战壹佰贰拾玖react-admin+material ui-react-admin之SortButton之使用
前端项目实战壹佰贰拾玖react-admin+material ui-react-admin之SortButton之使用
56 0
|
前端开发
前端项目实战壹佰贰拾柒react-admin+material ui-react-admin之FilterList之使用
前端项目实战壹佰贰拾柒react-admin+material ui-react-admin之FilterList之使用
55 0