vue3项目实战的请求接口问题(二)配置全局axios的nprogress顶部进度条

知识回调

文章内容文章链接
NProgress的使用(一)vue项目中使用NProgresshttps://blog.csdn.net/XSL_HR/article/details/129820542?spm=1001.2014.3001.5501
vue3项目实战的请求接口问题(一)跨域问题+解决方法https://blog.csdn.net/XSL_HR/article/details/127813674?spm=1001.2014.3001.5502

场景复现

无论是在后台管理系统的页面中,还是在其他网页中,拥有反馈页面加载进度的进度条已经是必要的了。在上期文章中,我们介绍了NProgress的基础用法,能在vue项目中引入与应用NProgress组件。不过在上期文章中,我们只是将NProgress与路由守卫相结合,本期文章将重点介绍如何将NProgress与axios请求相结合,实现页面请求进度的实时监听,增强交互体验。

具体需求: 通过进度条实时反映接口请求的进度
解决方法:使用NProgress组件和axios请求


下面来进行代码的实战来实现上述需求👇👇👇

利用NProgress和axios结合实现接口请求进度的实时反馈

1.引入NProgress

首先,在使用NProgress之前,我们需要在相应的文件中引入NProgress。
我这里是在根目录src下的utils文件里创建了一个request.ts的文件用于存放axios请求的部分

在这里插入图片描述
源代码

import axios from 'axios'
import { message, Modal } from 'ant-design-vue';
import NProgressE from 'nprogresse';
import 'nprogresse/style.css';

2.创建axios实例与超时设置

const request = axios.create({
    baseURL: '/store', // url = base url + request url
    timeout: 360000
    // withCredentials: true // send cookies when cross-domain requests
})

详细解释

  • 在这里使用了跨域处理(知识回调中可查看)
  • 设置请求时间不超过360000毫秒

3.NProgress与request结合

源代码

request.interceptors.request.use(
    (response) => {
        NProgressE.start()
        const satoken = localStorage.getItem('token')
        if (satoken !== '') {
            response.headers['token'] = satoken
        }
        return response
    },
    (error) => {
        NProgressE.error(true);
        Promise.reject(error)
    }
)

详细解释

  • 当请求开始时,调用start方法,开启进度条
  • 将登录时请求接口返回的token值取出来,进行token的校验
  • 如果校验成功,则进度条顺利加载到结束。如果请求失败或者校验不成功,都会导致进度条变成error状态,并返回错误提示

4.NProgress与response结合

源代码

request.interceptors.response.use(
    (response) => {
        NProgressE.done(true)
        const res = response.data;
    if (res.code == 30007) {
        Modal.warning({
        title: '登录过期',
        content: '请重新登录',
        onOk() {
            localStorage.setItem('token', '')
            location.reload() // To prevent bugs from vue-router
            },
        });
    }
        return response
    },
    (error) => {
        NProgressE.error(true);
        message.error(error.message)
        return Promise.reject(error)
    }
)

详细解释

  • 当请求成功时,调用done方法,结束进度条
  • 进行登录是否过期校验,如果身份过期则弹窗提示,进行重新登录操作。如果身份未过期且请求成功,则顺利加载进度条至结束
  • 如果请求失败,则进度条变为error状态,并返回错误提示

到目前为止,需求已经全部实现,具体的实现效果需要亲自搭建并实战!关于进度显示的问题,还有很多方法,比如使用ant design vue组件库中的spin组件与请求的状态相绑定,也能实现请求进度的精准实时反馈。(下期文章详细介绍)

在这里插入图片描述

下期文章将介绍vue antd spinning动画的使用(增强交互体验)
感兴趣的小伙伴可以订阅本专栏,方便后续了解学习~
觉得这篇文章有用的小伙伴们可以点赞➕收藏➕关注哦~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Dorable_Wander

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值