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>
相关推荐
光影少年17 小时前
angular生态及学习路线
前端·学习·angular.js
記億揺晃着的那天19 小时前
Vue + Element UI 表格自适应高度如何做?
javascript·vue.js·ui
无尽夏_19 小时前
HTML5(前端基础)
前端·html·html5
Jagger_19 小时前
敏捷开发流程-精简版
前端·后端
FIN666820 小时前
昂瑞微冲刺科创板:创新驱动,引领射频芯片国产化新征程
前端·安全·前端框架·信息与通信·芯片
GISer_Jing20 小时前
ByteDance——jy真题
前端·javascript·面试
睡美人的小仙女12720 小时前
浏览器为何屏蔽本地文件路径?
前端
真的想不出名儿20 小时前
Vue 中 props 传递数据的坑
前端·javascript·vue.js
FIN666820 小时前
昂瑞微:深耕射频“芯”赛道以硬核实力冲刺科创板大门
前端·人工智能·科技·前端框架·信息与通信·智能
阳光阴郁大boy20 小时前
星座运势网站技术解析:从零打造现代化Web应用
前端·javascript