当前位置:首页 > VUE

vue请求实现进度条

2026-01-12 08:10:59VUE

实现请求进度条的方法

在Vue中实现请求进度条可以通过多种方式完成,常见的有使用axios拦截器和第三方库如NProgress。以下是具体实现方法:

使用axios拦截器配合NProgress

安装NProgress库:

npm install nprogress

在Vue项目中配置axios拦截器:

vue请求实现进度条

import axios from 'axios';
import NProgress from 'nprogress';
import 'nprogress/nprogress.css';

axios.interceptors.request.use(config => {
  NProgress.start();
  return config;
});

axios.interceptors.response.use(response => {
  NProgress.done();
  return response;
}, error => {
  NProgress.done();
  return Promise.reject(error);
});

自定义进度条组件

创建自定义进度条组件:

<template>
  <div class="progress-bar" :style="{ width: progress + '%' }"></div>
</template>

<script>
export default {
  data() {
    return {
      progress: 0
    };
  },
  methods: {
    start() {
      this.progress = 0;
      const interval = setInterval(() => {
        this.progress += 10;
        if (this.progress >= 100) {
          clearInterval(interval);
        }
      }, 300);
    },
    finish() {
      this.progress = 100;
      setTimeout(() => {
        this.progress = 0;
      }, 500);
    }
  }
};
</script>

<style>
.progress-bar {
  height: 3px;
  background-color: #42b983;
  transition: width 0.3s ease;
}
</style>

在main.js中全局注册:

vue请求实现进度条

import ProgressBar from './components/ProgressBar.vue';

const progress = new Vue(ProgressBar).$mount();
document.body.appendChild(progress.$el);

Vue.prototype.$progress = {
  start: progress.start,
  finish: progress.finish
};

使用vue-router的导航守卫

结合vue-router实现页面切换时的进度条:

import NProgress from 'nprogress';

router.beforeEach((to, from, next) => {
  NProgress.start();
  next();
});

router.afterEach(() => {
  NProgress.done();
});

注意事项

进度条样式可以通过CSS自定义,NProgress默认提供蓝色进度条,可以通过修改CSS文件更改颜色和样式。

对于文件上传等长时间请求,需要在上传方法中手动控制进度:

axios.post('/upload', formData, {
  onUploadProgress: progressEvent => {
    const percent = Math.round((progressEvent.loaded * 100) / progressEvent.total);
    this.$progress.progress = percent;
  }
})

以上方法可以根据项目需求选择使用,NProgress方案较为成熟,自定义组件则更加灵活。

标签: 进度条vue
分享给朋友:

相关文章

vue实现aop切面

vue实现aop切面

Vue 实现 AOP 切面编程的方法 在 Vue 中实现 AOP(面向切面编程)可以通过多种方式,以下是几种常见的实现方法: 使用 Vue 混入(Mixins) Vue 的混入机制可以用于实现横切关…

vue实现购物按钮

vue实现购物按钮

Vue 购物按钮实现方法 基础按钮实现 使用 Vue 的模板语法创建基础按钮组件,绑定点击事件处理购物逻辑: <template> <button @click="addToC…

vue表格重置怎么实现

vue表格重置怎么实现

重置表格数据的方法 在Vue中重置表格数据通常需要操作绑定的数据源,以下是几种常见实现方式: 直接重置数据源 // 假设表格绑定的是tableData this.tableData = [...t…

vue实现压缩上传文件

vue实现压缩上传文件

压缩上传文件的实现方法 在Vue中实现文件压缩和上传功能,可以通过以下步骤完成。该方法结合了前端文件压缩库和HTTP请求,确保文件在上传前被有效压缩。 安装必要的依赖 需要使用compressor…

vue如何实现到期提醒

vue如何实现到期提醒

实现 Vue 到期提醒功能 使用计算属性计算剩余时间 在 Vue 组件中定义一个计算属性,计算目标日期与当前日期的差值。通过 Date 对象获取时间戳并计算剩余天数或小时数。 computed:…

vue怎么实现数据检测

vue怎么实现数据检测

Vue 数据检测的实现方式 Vue 通过响应式系统实现数据检测,核心机制基于 Object.defineProperty(Vue 2)或 Proxy(Vue 3)。以下是具体实现方法: 基于 Vu…