vue3+ts+elementplus 进度条制作浏览器进度条

开发工具:vue3 + ts + elementplus + el-progress

NProgress

在布署的时候,Jenkins总是提示失败,指向NProgress的问题,但是我却不知道为何,找不到相关解决方案,一气之下,就打算用别的方案了。

javascript 复制代码
<template>
  <div class="wrapper-progress">
    <Transition name="fade">
      <el-progress v-if="show" v-bind="attrs" :color="colors" :percentage="perc" :show-text="false" stroke-width="3" />
    </Transition>
  </div>
</template>
<script setup lang="ts">
import { ref, defineProps, defineEmits, computed, useAttrs } from "vue";
import type { Ref } from "vue";
const attrs = useAttrs(); //所有非defineProps中定义的属性

const emits = defineEmits(["start", "finish", "update:size"]);

// 组件属性
const props = defineProps({
  percentage: {
    type: Number,
    default: 20,
  },
  setp: {
    type: Number,
    default: 8,
  },
  per: {
    type: Number,
    default: 150,
  },
});
let maxNum: number = 90;
const colors: Object[] = [
  { color: "#f56c6c", percentage: 20 },
  { color: "#e6a23c", percentage: 40 },
  { color: "#5cb87a", percentage: 60 },
  { color: "#1989fa", percentage: 80 },
  { color: "#36CEBF", percentage: 100 },
];

let show: Ref<boolean> = ref(false);
let perc: any = ref(0);

//开始事件
const start = () => {
  show.value = true;
  function task() {
    if (perc.value > maxNum) {
      perc.value = maxNum;
      clearInterval(intervalID);
    }
    perc.value = perc.value + props.setp;
  }

  // 执行
  let intervalID = setInterval(() => {
    task();
  }, props.per);
};

// 完成事件
const finish = () => {
  perc.value = 100;
  setTimeout(() => {
    show.value = false;
  }, 500);
};

defineExpose({
  start,
  finish,
});
</script>

<style lang="scss" scoped>
.wrapper-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 10px;
  z-index: 999;

  .fade-enter-active,
  .fade-leave-active {
    transition: opacity 0.5s ease;
  }

  .fade-enter-from,
  .fade-leave-to {
    opacity: 0;
  }
}
</style>
相关推荐
一心赚狗粮的宇叔10 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
子春一10 小时前
Flutter for OpenHarmony:音律尺 - 基于Flutter的Web友好型节拍器开发与节奏可视化实现
前端·flutter
JarvanMo10 小时前
150万开发者“被偷家”!这两款浓眉大眼的 VS Code 插件竟然是间谍
前端
亿元程序员10 小时前
大佬,现在AI游戏开发教程那么多,你不搞点卖给大学生吗?
前端
未来龙皇小蓝10 小时前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
空白诗10 小时前
高级进阶 React Native 鸿蒙跨平台开发:slider 滑块组件 - 进度条与评分系统
javascript·react native·react.js
晓得迷路了11 小时前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js
How_doyou_do11 小时前
执行上下文、作用域、闭包 patch
javascript
叫我一声阿雷吧11 小时前
深入理解JavaScript作用域和闭包,解决变量访问问题
开发语言·javascript·ecmascript
淡忘_cx11 小时前
使用Jenkins自动化部署vue项目(2.528.2版本)
vue.js·自动化·jenkins