全局前置路由守卫(beforeEach)

news/2024/7/10 1:33:57 标签: javascript, 前端, vue, 前端框架

全局前置路由守卫(beforeEach)

  • 功能:每一次切换任意路由组件之前都会被调用,相当于在进入另一个路由组件之前设置一个权限。
    • 路由守卫的存在意义就是在不同的时间,不同的位置,去添加代码。
    • 如:Java的filter(过滤器):在使用哪段代码前先进行过滤(效果类似)

在这里插入图片描述

使用方法

  • 代码创建的位置:
    • 在创建router之后(const router = new VueRouter
    • 暴露router之前(export default router
  • beforeEach中的回调函数在什么时候被调用?
    • 在初始化的时候执行一次,每一次切换任意路由组件之前都会调用一次
    • 回调函数没有固定形式,普通函数或箭头函数都可以
  • 回调函数有三个参数:
    • to参数:to是一个路由对象,表示到哪儿去(跳转的下一个路由组件)。
    • from参数:form是一个路由对象,表示从哪来(从哪个路由切换过来的)。
    • next参数:next是一个函数,表示允许通过,可以继续向下走。
  • 格式:router.beforeEach((to, from, next) => {})
  • 自定义属性(meta):在路由对象的添加meta(路由元)
    • 格式:meta : {属性名:''}
    • title属性:可以修改页面标题
  • 以下代码执行效果:通过修改网页标题实现beforeEach的效果

在这里插入图片描述

javascript">// index.js
import VueRouter from 'vue-router'

import HuBei from '../pages/HuBei'
import City from '../pages/City'

const router = new VueRouter({
    routes : [
        {
            name : 'bei',
            path : '/hubei',
            component : HuBei,
            meta : {title : '湖北省'},
            children : [
                {
                    name : 'wh',
                    path : 'wuhan',
                    component : City,
                    props : true,
                    meta : {
                        isAuth : true,
                        // 设置页面标题
                        title : '武汉市'
                    }
                },
                {
                    name : 'hs',
                    path : 'huangshi',
                    component : City,
                    props : true,
                    meta : {
                        isAuth : true,
                        title : '黄石市'
                    }
                }
            ]
        }
    ]

})

// 全局前置路由守卫
router.beforeEach((to, from, next) => {
    let loginName = 'admin'
    // 登录名不相同时显示‘对不起,您没有权限’
    if(to.meta.isAuth){
        if(loginName === 'root'){
            document.title = to.meta.title
            next()
        }else{
            alert('对不起,您没有权限')
        }
    }else{
        document.title = to.meta.title
        next()
    }
})

export default router
javascript">// App.vue
<template>
    <div>
        <h2></h2>
        <div>
            <ul>
                <li>
                    <router-link to="/hubei">湖北省</router-link>
                </li>
            </ul>
            <router-view></router-view>
        </div>
    </div>
</template>

<script>
    export default {
        name : 'App'
    }
</script>
javascript">// HuBei.vue
<template>
    <div>
        <h2></h2>
        <div>
            <ul>
                <li>
                    <router-link :to="{
                        name : 'wh',
                        params : {
                            a1 : wh[0],
                            a2 : wh[1],
                            a3 : wh[2],
                        }
                    }">
                        武汉市
                    </router-link>
                </li>
                <li>
                    <router-link :to="{
                        name : 'hs',
                        params : {
                            a1 : hs[0],
                            a2 : hs[1],
                            a3 : hs[2],
                        }
                    }">
                        黄石市
                    </router-link>
                </li>
            </ul>
            <router-view></router-view>
        </div>
    </div>
</template>

<script>
    export default {
        name : 'HuBei',
        data(){
            return{
                wh : ['江岸区', '江汉区', '桥口区'],
                hs : ['下陆区', '铁山区', '西塞山区']
            }
        }
    }
</script>
javascript">// City.vue
<template>
    <div>
        <h2></h2>
        <ul>
            <li>{{a1}}</li>
            <li>{{a2}}</li>
            <li>{{a3}}</li>
        </ul>
    </div>
</template>

<script>
    export default {
        name : 'City',
        props : ['a1', 'a2', 'a3']
    }
</script>

http://www.niftyadmin.cn/n/5166816.html

相关文章

NSSCTF第11页(3)

[羊城杯 2020]easyphp 源码 发现会在写入文件之前会删除目录下的除了index.php的文件。写入文件的文件名和文件内容也是可控的&#xff0c;只不过存在过滤 stristr函数对文件内容进行过滤&#xff0c;该函数绕过还是简单的&#xff0c;只需要添加一些特殊字符就可以了&#…

使用 Wireshark 抓包工具快速分析 IoT 物联网终端设备的网络通信行为

当你进行 IoT 物联网开发过程中&#xff0c;终端-MQTT 服务器-业务系统-App 全链路联调时往往难以快速定位问题&#xff1a;终端可能未正常发出消息报文&#xff0c;也可能在网络传输中丢失&#xff0c;也可能被 MQTT 服务器限流丢弃&#xff0c;或者业务系统处理异常而丢失。此…

pinpoint监控tomcat应用,页面显示No data collected

pinpoint安装部署教程大家都可以搜到。这里就不说了。单说一下 页面没有数据的情况。 部署环境&#xff0c;pinpoint安装部署在A服务器上。现在是在C、D、E、F……linux机器上安装pinpoint-agnet 1. 将文件 pinpoint-agent-1.8.5.tar.gz 上传到 服务器C、D、E、F…… 2. 解压…

Opencv for unity 下载

GitHub - EnoxSoftware/VideoPlayerWithOpenCVForUnityExample: This example shows how to convert VideoPlayer texture to OpenCV Mat using AsyncGPUReadback. OpenCV for Unity | Integration | Unity Asset Store

SAP ABAP基础语法-Excel上传(十)

EXCEL BDS模板上传及赋值 上传模板事务代码&#xff1a;OAER l 功能代码&#xff1a;向EXCEL模板中写入数据示例代码如下 REPORT ZEXCEL_DOI. “doi type pools TYPE-POOLS: soi. *SAP Desktop Office Integration Interfaces DATA: container TYPE REF TO cl_gui_custom_c…

在使用ubuntu18.04的时候使用阿里源或者清华源后安装mysql5.7时出现dpkg提示的错误信息

在使用ubuntu18.04的时候使用阿里源或者清华源后安装mysql5.7时出现dpkg提示的错误信息 经过排查发现该问题可能跟本地库依赖文件导致mysql安装不上。 清除刚下载保留的mysql&#xff0c;然后删除、清除在更新本地依赖库。 sudo apt purge mysql* sudo apt autoremove sudo …

GitHub Copilot Chat将于12月全面推出;DeepLearning.AI免费新课

&#x1f989; AI新闻 &#x1f680; GitHub Copilot Chat将于12月全面推出&#xff0c;提升开发者的生产力 摘要&#xff1a;GitHub宣布将于12月全面推出GitHub Copilot Chat&#xff0c;这是GitHub Copilot的一个新功能&#xff0c;旨在帮助开发者编写代码。它能够集成到开…

【qemu逃逸】XCTF 华为高校挑战赛决赛-pipeline

前言 虚拟机用户名: root 无密码 设备逆向与漏洞分析 程序没有去符合, 还是比较简单. 实例结构体如下: 先总体说一下流程: encode 为 base64 编码函数, decode 为 base64 解码函数. 然后 encPipe 和 decPipe 分别存放编码数据和解码数据, 分别有四个: 其中 EncPipeLine 中…