04-vuePC端项目(layout页面布局,权限控制的路由导航守卫,嵌套路由,axios发送请求前拦截器,响应数据前拦截器)

本文主要是介绍04-vuePC端项目(layout页面布局,权限控制的路由导航守卫,嵌套路由,axios发送请求前拦截器,响应数据前拦截器),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

登录成功之后完成layout页面

layout文件夹下的index.vue
<template><el-container class="layout"><el-header class="header"><div class="left"><i class="el-icon-s-fold" @click="isCollapse=!isCollapse"></i><img src="@/assets/layout_icon.png" class="marginlr" alt /><span class="title">黑马面面</span></div><div class="right"><img :src="avatar" alt /><span class="name">{{username}},您好</span><el-button size="mini" type="primary" @click="logout">退出</el-button></div></el-header><el-container><el-aside width="auto"><!-- 左侧导航栏 --><el-menu default-active="5" class="el-menu-vertical-demo" :collapse="isCollapse" router><el-menu-item index="/layout/chart"><i class="el-icon-pie-chart"></i><span slot="title">数据概览</span></el-menu-item><el-menu-item index="/layout/user"><i class="el-icon-user"></i><span slot="title">用户列表</span></el-menu-item><el-menu-item index="/layout/question"><i class="el-icon-edit-outline"></i><span slot="title">题库列表</span></el-menu-item><el-menu-item index="/layout/enterprise"><i class="el-icon-office-building"></i><span slot="title">企业列表</span></el-menu-item><el-menu-item index="/layout/subject"><i class="el-icon-notebook-2"></i><span slot="title">学科列表</span></el-menu-item></el-menu></el-aside><el-main style="background-color: #e8e9ec"><router-view></router-view></el-main></el-container></el-container>
</template><script>
// 按需导入
import { removeToken } from "@/ultils/token";
export default {data() {return {isCollapse: false, //导航栏是否展示avatar: "", //用户头像username: "" //用户昵称};},methods: {// 发送请求得到用户信息async getUserData() {const res = await this.$axios.get("/info", {//这个在发送axios里面带过去也可以,但是后面每个请求都要写并且post与get方法写的地方还不一样// 就很麻烦,可以写在拦截器里面,只要发送请求都会先经过那里// headers: {//   token: getToken(),//在请求头把token带过去// }});// console.log(res);if (res.data.code == 200) {this.avatar = process.env.VUE_APP_BASEURL + "/" + res.data.data.avatar;this.username = res.data.data.username;}},// 退出logout() {this.$confirm("确定退出吗?", "提示", {confirmButtonText: "确定",cancelButtonText: "取消",type: "warning"}).then(async () => {const res = await this.$axios.get("/logout");if (res.data.code == 200) {//退出要把token删掉removeToken();//还要去到登录页面this.$router.push("/login");}}).catch(() => {});}},created() {this.getUserData();}
};
</script>

项目说明:在这里插入图片描述

01-权限控制

前端要做
  • 导航守卫:简单一点说就是当你没有登录的时候(也就没有token),就看你有没有登录,没登录就没权限访问其他路由的页面,就都要被打回登录页面去
    直通车:直通车: vue Router中文档中的导航守卫.
    • 作用:我们没进入一个页面之前,它会拦截到,然后,在导航守卫中进行判断,如果有权限,就让你访问你要去的页面,如果没有权限,可以通过路由跳转到指定页面
    • 是一个函数,它里面有三个参数:
      to, 我们要去的页面
      from,之前的页面
      next,控制着你是否有权,访问你想去的页面
  • 代码实现
    在 src/router/index.js 中写导航守卫的代码:
// 按需导入(要用到这个所以要导入)
import { getToken} from '@/ultils/token'// 全局导航守卫
router.beforeEach((to, from, next) => {//console.log(to);// console.log(from);//先判断to的是不是登录页面,如果是登录页面就没必要守卫直接通关if (to.fullPath == "/login") {next()} else {// 如果to的不是非登录页面,那就判断你有没有先登录能不能取到token,如果能就表示你登录了让你通关,没有登录就打回登录页面const token = getToken()if (token) {next(); //去到你想去的地方} else {next("/login")}}})
后台也要做

比如有些是从postman里面添加数据啥的也不行所以后台也要控制把关做权限控制


02-layout页面布局

容器布局

直通车: elementui里面的Container布局容器.

菜单

1、直通车: elementui里面的NavMenu导航菜单.

2、 其它:

  • 控制菜单的展开和收起:collapse=“isCollapse” ,由这个isCollapse是true还是false决定,默认false是展开的
  • 控制高亮
    el-menu-item 上面的 index
    el-menu中的default-active
点击左边菜单项,希望发生的变化

1、浏览器的导航栏中,路由地址发生改变
el-menu,设置 router 属性为true
更改 el-menu-item 中的 index的值,改成路径
2、右边内容部分也要发生变化: 嵌套路由
3、左边的高亮状态发生改变,并且刷新也能够显示正常

03-嵌套路由

在这里插入图片描述

在 router.js 中配置

直通车: vue Router文档中的嵌套路由.

应用场景:

后台管理系统中

步骤:

1、在layout.vue中的 右边设置一个 router-view
2、在 src/router/index.js 中配置 layout页面右边的路由规则
嵌套路由:注意嵌套着的路由的path:‘chart’ 这种千万别在chart前面加/,否则出有问题

const router = new VueRouter({routes: [{path: '/login',component: Login},{path: '/layout',component: Layout,//这个children数组里面的就是嵌套着的路由children: [{path:'chart',component:Chart},{path:'user',component:User},{path:'enterprise',component:Enterprise},{path:'question',component:Question},{path:'subject',component:Subject},]},{path: '/',redirect: '/login'}]
});] },

3、还要在layout结构中的对应的嵌套结构中里面写上router-view标签

 <el-main style="background-color: #e8e9ec"><router-view></router-view></el-main>

04个人信息展示与退出

  • 个人信息获取:
    发送请求得到个人信息,它需要请求头中携带token(因为要保证你确定是登录了的,如果是登录了的就一定可以拿到token才能发送请求响应回来给你)
    1、在每个请求中都写设置请求头的代码: 每一都得写,并且get方法和post方法写的地方还不一样,这个被注释掉的就很麻烦
created() {this.getUserData();},methods: {// 发送请求得到用户信息async getUserData() {const res = await this.$axios.get("/info", {//这个在发送axios里面带过去也可以,但是后面每个请求都要写并且post与get方法写的地方还不一样// 就很麻烦,可以写在拦截器里面,只要发送请求都会先经过那里// headers: {//   token: getToken(),//在请求头把token带过去// }});// console.log(res);if (res.data.code == 200) {this.avatar = process.env.VUE_APP_BASEURL + "/" + res.data.data.avatar;this.username = res.data.data.username;}},

比如在get请求中携带token在这里插入图片描述
比如在post请求中携带token在这里插入图片描述
        2、我们可以统一的在请求拦截器中设置请求头(src/utils/request.js中编写),好处就是只用写一次。
             直通车: axios中的拦截器Interceptors.

src/ultils/request.js文件下:

// 按需导入
import { getToken } from "@/ultils/token";
import { removeToken } from "@/ultils/token";
import router from '@/router/index'// 请求拦截器,发送请求前要经过这里,发送请求要把token带过去可以在这里面写
axios.interceptors.request.use(function (config) {// Do something before request is sentconst token = getToken()if (token) {config.headers.token = token}return config;
}, function (error) {// Do something with request errorreturn Promise.reject(error);
});//响应拦截器,返回的数据都要先经过这里,可以把token过期的处理可以在这里写
axios.interceptors.response.use(function (response) {// Do something with response data// 如果响应回来的code为206说明就是token过期了,那就要返回登录页面并且把token删除if (response.data.code == 206) {removeToken();// 这个js里面可以把router文件夹下的index.js实例化的router拿过来就相等于vue的单文件组件的this.$routerrouter.push('/login')return;}//如果没问题就返回响应return response;}, function (error) {// Do something with response errorreturn Promise.reject(error);});
  • 退出
    直通车: elementui中的MessageBox 弹框.
    弹出一个框问客户确定退出吗?用户选择确定之后,我们需要做如下的事情
    1、发请求,告诉后台该用户要退出了,后台应该要做一些处理
    2、退出成功之后,做两件事情,第一 删除token,第二 跳转到登录页面

这篇关于04-vuePC端项目(layout页面布局,权限控制的路由导航守卫,嵌套路由,axios发送请求前拦截器,响应数据前拦截器)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/807241

相关文章

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

SpringBoot请求参数传递与接收示例详解

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录I. 基础参数传递i.查询参数(Query Parameters)ii.路径参数(Path Va

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环