Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解

   2023-02-08 学习力0
核心提示:目录一、声明式导航编程式导航二、导航守卫三、axios拦截器一、声明式导航编程式导航1. 声明式导航:以超链接方式实现的页面跳转,就是声明式导航 a href=‘url’ 链接文本或图像/arouter-link to=‘url’链接文本或图像/router-link 2. 编程式导航:通过java

一、声明式导航&编程式导航

1. 声明式导航:以超链接方式实现的页面跳转,就是声明式导航

< a href=‘url’> 链接文本或图像 < /a >

< router-link to=‘url’ > 链接文本或图像 < /router-link >

2. 编程式导航:通过javascript提供的api方法实现页面的跳转,就是编程式导航

location.href = ‘url’

location.go(number)

location.replace(‘url’)

3. vue-router中提供的编程式导航的API

​ (1)this.$router.push(‘url’):将‘url’添加到路由表中,增加了一条路由记录

<template>
<div>
 <h3>Home 组件</h3>
 <button @click="gotoMovie">跳转到 Movie 页面</button>
</div>
</template>
<script>
export default {
  name: "",
  methods:{
    gotoMovie(){
      this.$router.push('/movie/1')
    }
  }
}
</script>

​ (2)this.$router.replace(‘url’):跳转到url中,并替换掉当前的历史记录

​ push 和 replace 的区别:

​ ​ 1)push 会增加一条历史记录

​ ​ 2)replace 不会增加历史记录,而是替换掉当前的历史记录

​ (3)this.$router.go(number):参数是一个数值,页面跳转到指定的位置,可以在浏览历史中前进和后退。

​ ​ (4)this.$router.go()的简化写法

​ ​ ​ 1)this.$router.back():在历史记录中,后退到上一个页面

​ ​ ​ 2)this.$router.forword():在历史记录中,前进到下一个页面

<template>
<div>
 <h3>Home 组件</h3>
 <button @click="goBack">退回上一页</button>
</div>
</template>
<script>
export default {
  props:['id'],
  methods:{
    goBack(){
      this.$router.go(-1)
    }
  }
}
</script>

二、导航守卫

1. 用途:在页面导航过程中实现重定向、取消路由、权限验证等业务。

​ 导航守卫分为三类:全局守卫、路由独享的守卫、组件内守卫,可以用于路由导航过程中的不同阶段。

​ 每一个导航守卫都有三个参数:to、from 和 next (router、afterEach 除外)

Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解

​ 2. 分类:全局守卫、组件内部守卫、路由独享的守卫

​ 3. 全局守卫

​ ​ (1)全局前置守卫:每次发生路由的导航跳转时,都会触发全局前置守卫。因此,在全局前置守卫中,程序员可以对每个路由进行访问权限的控制。使用的router.beforeEach(to,from,next){ }来注册。当一个导航触发时,全局前置守卫按照路由创建的顺序调用。

  • to:将要访问的路由的信息对象
  • from:将要离开的路由的信息对象
  • ​next:是一个函数,调用next()表示当前路由已经放行

​ ​ (2)next调用的情况

​ ​ 1)用户拥有了权限,直接放行:next()

​ ​ 2)用户没有权限,强制跳转到指定的页面:next(‘/login’)

​ ​ 3)用户没有权限,不允许访问:next(false)

Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解

​ ​ 4. 全局前置守卫的使用

​ ​ ​ (1)创建Login.vue组件

​ ​ ​ (2)在路由文件router / index.js中注册全局的前置守卫

//App.vue
<template>
  <div>
    <h2>{{ info }}</h2>
    <div>
      <label>
        账号:<input type="text" v-model.trim="userName" />
      </label>
      <br /><br />
      <label>
        密码:<input type="password" v-model.trim="passWord" />
      </label>
      <br /><br />
      <button type="button" @click="login">登录</button>
    </div>
  </div>
</template>
<script type="text/javascript">
import $http from '../axios/index'
export default {
  name: "Login",
  data() {
    return {
      info: '',
      userName: '',
      passWord: '',
    }
  },
  methods: {
    login() {
      //   //对登陆信息进行验证(实际中在此处进行ajax的请求)
      //   if('lisi' === this.userName && '1234' === this.passWord){
      //     sessionStorage.setItem('isAuth',true) //在页面缓存中保存isAuth,isAuth=true表示用户已登录
      //     this.info = ''
 
      //     //判断当前路由对象中参数是否有参数
      //     if(this.$route.query.redirect){
      //       let redirect =this.$route.query.redirect
      //       this.$router.replace(redirect)//跳转到指定页面
      //     }
      //     else{
      //       this.$router.replace('/')//若路由对象中没有redirect,则直接跳转到默认的首页
      //     }
      //   }else{//非法用户
      //   sessionStorage.setItem('isAuth',false)
      //   this.userName = ''
      //   this.passWord = ''
      //   this.info = '用户名或密码错误'
      // }
      $http.post('/test/login', {
        userName: this.userName,
        passWord: this.passWord
      }).then(res => {
        if (res.data.code == 200) {
          sessionStorage.setItem('auth', res.data.tokenInfo)
          this.info = ''
          //判断当前路由对象中参数是否有参数
          if (this.$route.query.redirect) {
            let redirect = this.$route.query.redirect
            this.$router.replace(redirect)//跳转到指定页面
          }
          else {
            this.$router.replace('/')//若路由对象中没有redirect,则直接跳转到默认的首页
          }
        } else {
          sessionStorage.setItem('auth', '')
          this.userName = ''
          this.passWord = ''
          this.info = '用户名或密码错误'
        }
      })
    }
  }
}
</script>
<style scoped>
</style>
//router/insex.js
//注册全局前置导航守卫
router.beforeEach((to, from, next) => {
    //判断目标路由是否是/login,如果是,则直接调用next()方法
    if (to.path == '/login') {
        next()
    } else {//否则判断用户是否已经登录,注意这里是字符串判断
        if (sessionStorage.getItem('auth')!='' && sessionStorage.getItem('auth'!=null)) {
            next()
        } else {//如果用户访问的是受保护的资源,且没有登录,则跳转到登录页面
            //并将当前路由的完整路径作为查询参数传递给Login组件,以便登录成功后返回先前的页面
            next({//强制跳转到登录页面
                path: '/login',
                query:{ redirect:to.fullPath}
            }
            )
        }
    }
})

三、axios拦截器

1. axios模块的作用:是对基于http请求的封装。在浏览器对异步请求对象XMLHttpRequest进行封装

2. 拦截器

​ (1)请求拦截器:对客户端发起的请求进行统一的前期处理(token、时间戳、cookie等)

​ (2)响应拦截器:对服务器端响应给客户端的数据统一进行处理之后再发给客户端

Vue声明式导航与编程式导航及导航守卫和axios拦截器全面详细讲解

3. 使用方法

//前端/App.vue
<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
  <br/>  <br/>
  <button @click="login">登录</button>
  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  <button @click="test">测试拦截器</button>
  </div>
</template>
<script>
import $http from './axios/index'
export default {
  name: 'App',
  methods:{
    login(){
      $http.post('/users/login',{
        userName:'lisi',
        userPwd:'12345'
      }).then(res=>{
        if(res.data.code == 200){
          sessionStorage.setItem('Auth',res.data.mytoken)
        }
      }).catch(err=>{
        console.log(err);
      })
    },
    test(){
      $http.post('/users/test').then(res=>{
        console.log(res.data);
      }).catch(err=>{
        console.log(err);
      })
    }
  }
}
</script>
//前端/index.js
import axios from "axios";
//1. 创建axios的实例,配置基础路径
const axiosInstance = axios.create({
    baseURL: 'http://localhost:8089',
    timeout: 5000
})
//2. 定义请求拦截器:给所有请求都带上token
axiosInstance.interceptors.request.use((req) => {
    let token = sessionStorage.getItem('Auth') //获取页面存储中的token信息
    if (token) { //若token存在
        req.headers['Auth'] = token
    }
    return req;
}, (err) => {
    return Promise.reject(err)
})
// 3.响应拦截器:对服务器响应给客户端的数据进行统一的处理
axiosInstance.interceptors.response.use((res) => {
    //1.对响应数据进行处理
    let result = res.data
    let code = result.code
    if (code == 200) {
        return result
    } else {
        return Promise.reject(result)
    }
}, (err) => {
    return Promise.reject(err)
})
export default axiosInstance
//后台/usrs.js
var express = require('express');
var router = express.Router();
var jwt = require('jsonwebtoken')
/* http://localhost:8089/users/login */
router.post('/login', (req, res)=>{
  //1.接收客户的请求数据
  let user = {
    name:req.body.userName,
    pwd:req.body.userPwd
  }
  //2.定义密钥
  let temp = 'baihualin'
  //3.生成token
  let token = jwt.sign(user,temp)
  res.json({
    code:200,
    mytoken:token
  })
} );
/* http://localhost:8089/users/login */
router.post('/test',(req,res)=>{
  //输出请求头信息
  console.log(req,headers)
  let arr = [
    {
      bookId:1001,
      bookName:'Vue2从入门到精通',
      publish:'清华大学出版社'
    }, 
    {
      bookId:1002,
      bookName:'Html从入门到放弃',
      publish:'清华大学出版社'
    }, 
    {
      bookId:1003,
      bookName:'Css都是浮云',
      publish:'清华大学出版社'
    }, 
  ]
  res.json(arr)
})
module.exports = router;
原文地址:https://blog.csdn.net/m0_74343097/article/details/128658722
 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 写react vue要规范,结尾的冒号,之间的逗号一
    写react  vue要规范,结尾的冒号,之间的逗号一定要写规范,写全
    03-08
  • 【转】React、Vue访问NotFound
    部署完成后,访问没问题,从页面中点击跳转也没问题,但是只要点击刷新或通过浏览器地址栏回车,就会出现404现象!在本地开发中是没有这个问题的,调试的时候一切都是正常的直接访问地址,便会出现404http://www.xxx.com/home/application/list问题原因:刷新
    03-08
  • 移动端悬浮框可移动,可回弹,Vue and React
    一,首先讲 React的悬浮框示例,可参照链接Demo文档,可参照链接 1. 安装npm install suspend-button -S2. 使用import React, { Component } from 'react'import ReactDOM from 'react-dom'import SuspendButton from 'suspend-button'class App extends Com
    03-08
  • react中虚拟DOM的基本概念 vue虚拟dom和react虚
    react中的核心概念1、DOM的本质是什么: 浏览器中的概念,用js对象来表示页面上的元素,并提供操作DOM对象的API2、什么事react中的虚拟DOM:是框架中的概念,是程序员用js对象来模拟页面上的DOM和DOM 的嵌套3、为什么要实现虚拟DOM:为了实现页面中DOM元素的
    03-08
  • React与Vue的相同与不同点 react和vue区别和看法
    React与Vue的相同与不同点 react和vue区别和看
    我们知道JavaScript是世界上最流行的语言之一,React和Vue是JS最流行的两个框架。所以要想前端的开发那么必须掌握好这两个框架。那么这两个框架有什么不同呢?React 和 Vue 相同之处,它们都有:使用 Virtual DOM提供了响应式 (Reactive) 和组件化 (Composabl
    03-08
  • vue3+TS 自定义指令:长按触发绑定的函数
    vue3+TS 自定义指令:长按触发绑定的函数而然间看到一个在vue2中写的长按触发事件的自定义指定,想着能不能把他copy到我的vue3项目中呢。编写自定义指令时遇到的几个难点1.自定义指令的类型在ts中写任何东西都要考虑到类型的问题,自定义指令的类型问题依然存
    03-08
  • Vue生命周期 vue生命周期几个阶段
    Vue生命周期 vue生命周期几个阶段
    官网解释一、Vue的生命周期Vue 实例有⼀个完整的⽣命周期,也就是从开始创建、初始化数据、编译模版、挂载Dom - 渲染、更新 - 渲染、卸载 等⼀系列过程,称这是Vue的⽣命周期。Vue2生命周期:1.beforeCreate(创建前)数据观测和初始化事件还未开始,此时 dat
    03-08
  • vue 中安装并使用echart
    vue 中安装并使用echart
    本文为博主原创,转载请注明出处:1.安装echart 依赖:  安装命令: npm install echarts --save  在vscode 的终端窗口进行执行,如图所示:   执行完之后,查看 项目中的echart 版本依赖是否添加成功:  package-lock.json 中有具体的echart 依赖
    03-08
  • day04-Vue01
    day04-Vue01
    Vue011.Vue是什么?Vue(读音/vju:/,类似于view)是一个前端框架,依据构建用户界面Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或者项目整合支持和其他类库结合使用开发复杂的单页应用非常方便Vue是Vue.js的简称官网:Vue.js - 渐进式 JavaScr
    03-08
  • Vue + Element 自定义上传封面组件
    Vue + Element 自定义上传封面组件
    前一段时间做项目,频繁使用到上传图片组件,而且只上传一个封面,于是想着自定义一个图片封面上传组件。先来看一下效果:                      第一张图片是上传之前,第二张图片是上传成功后,第3张图片是鼠标放上去之后的效果! 首先整理需
    03-08
点击排行