Vue 中动态实现进度条
在 Vue 中动态实现进度条,基本上有两种常见的方法:直接通过 Vue 数据绑定控制样式,或者利用外部库来实现更复杂的功能。我们会深入探讨这两种方式,并且详细说明每种方法的实现步骤、优缺点以及使用场景。
1. 使用 Vue 数据绑定来动态更新进度条
1.1 基本原理
Vue 的数据绑定可以帮助我们轻松实现动态效果。通过将 Vue 实例的 data 属性与 HTML 元素的 style 或 class 属性绑定,能够在数据变化时自动更新视图。这是动态更新进度条的一种基本方式。
1.2 实现步骤
1.2.1 创建基础的进度条组件
我们将使用 Vue 的 :style 语法动态绑定进度条的宽度。具体实现如下:
<template><div id="app"><div class="progress-bar"><div class="progress" :style="{ width: progress + '%' }"></div></div><button @click="startProgress">Start Progress</button></div>
</template><script>
export default {data() {return {progress: 0 // 进度值,初始为 0};},methods: {startProgress() {let interval = setInterval(() => {if (this.progress < 100) {this.progress += 5; // 每次增加 5} else {clearInterval(interval); // 达到100后停止}}, 1000); // 每秒更新一次}}
};
</script><style scoped>
.progress-bar {width: 100%;height: 30px;background-color: #f3f3f3;border-radius: 5px;overflow: hidden;
}.progress {height: 100%;background-color: #4caf50; /* 进度条的颜色 */transition: width 0.5s ease; /* 平滑过渡效果 */
}
</style>
1.3 代码分析
HTML: 我们在 progress-bar 容器中放置了一个 progress 元素,它的宽度由 :style 动态绑定 progress 数据属性来控制。width: progress + ‘%’ 表示进度条的宽度百分比随着 progress 值的变化而变化。
Vue 实例:
data 中定义了 progress,初始值为 0。
在 methods 中,我们定义了 startProgress 方法,通过 setInterval 每秒更新 progress 值,直到其达到 100 为止。
CSS: 我们为进度条添加了基本的样式。transition: width 0.5s ease 用于让进度条的宽度变化时有平滑的过渡效果,使进度条的变化看起来更加自然。
1.4 优缺点
优点:
- 简单易用,适用于不需要复杂交互的场景。
- 使用 Vue 的数据绑定机制,视图会自动更新,无需手动操作 DOM。
缺点:
- 只能控制进度条的宽度,无法实现更复杂的效果(如动画、颜色变换等)。
- 不适合处理全局的进度条(例如加载整个页面的进度)。
2. 使用外部库(如 vue-progressbar)
当我们需要更强大的进度条功能(如页面加载的全局进度条),可以使用像 vue-progressbar 这样的外部库。这些库提供了许多开箱即用的功能,能够帮助我们快速实现复杂的进度条。
2.1 安装 vue-progressbar
首先需要安装 vue-progressbar:
npm install vue-progressbar --save
2.2 引入并使用 vue-progressbar
在 Vue 项目中引入 vue-progressbar,并进行配置:
import VueProgressBar from 'vue-progressbar';Vue.use(VueProgressBar, {color: '#4caf50', // 设置进度条颜色failedColor: '#874b4b', // 失败时的颜色thickness: '5px', // 设置进度条厚度transition: {speed: '0.5s', // 进度条平滑过渡的速度opacity: '0.8s', // 进度条透明度过渡速度termination: 400 // 过渡终止时间}
});
2.3 使用进度条
在组件中,可以通过 $Progress 对象来控制进度条。下面是如何在按钮点击时动态更新进度条:
<template><div id="app"><button @click="startProgress">Start Progress</button></div>
</template><script>
export default {methods: {startProgress() {this.$Progress.start(); // 开始进度条let progress = 0;let interval = setInterval(() => {progress += 5;this.$Progress.set(progress); // 设置进度条的当前进度if (progress >= 100) {clearInterval(interval);this.$Progress.finish(); // 进度条完成}}, 500); // 每 500 毫秒增加 5%}}
};
</script>
2.4 代码分析
- this.$Progress.start():开始进度条。
- this.$Progress.set(progress):设置进度条当前进度。progress 是动态变化的。
- this.$Progress.finish():完成进度条,进度达到 100% 后结束。
2.5 优缺点
优点:
- 提供更多的自定义选项,如颜色、宽度、动画等。
- 可以用于全局进度条管理,适合处理页面加载、路由跳转等全局场景。
- 进度条操作简单,易于集成,减少了自定义实现的工作量。
缺点:
- 增加了项目的依赖,增加了复杂性。
- 如果只是需要简单的进度条,使用外部库可能会显得过于冗余。
相关文章:
Vue 中动态实现进度条
在 Vue 中动态实现进度条,基本上有两种常见的方法:直接通过 Vue 数据绑定控制样式,或者利用外部库来实现更复杂的功能。我们会深入探讨这两种方式,并且详细说明每种方法的实现步骤、优缺点以及使用场景。 1. 使用 Vue 数据绑定来…...
如何基于PyTorch做二次开发
基于PyTorch进行二次开发以实现可视化工程,可以从以下几个方面入手:模型结构可视化、训练过程监控、特征可视化等。以下是一些推荐的GitHub项目,这些项目可以帮助你快速搭建一个可视化的工程环境: ### 1. **PyTorch CNN Visualiz…...
Mac 版 本地部署deepseek ➕ RAGflow 知识库搭建流程分享(附问题解决方法)
安装: 1、首先按照此视频的流程一步一步进行安装:(macos版)ragflowdeepseek 私域知识库搭建流程分享_哔哩哔哩_bilibili 2、RAGflow 官网文档指南:https://ragflow.io 3、RAGflow 下载地址:https://github.com/infi…...
算法——后缀平衡树
先回想一下之前讨论的内容。之前我们详细讨论了后缀树,包括它的构建、应用以及相关算法。用户可能是在了解后缀树之后,想要进一步探索相关的数据结构,或者是想比较后缀树和后缀平衡树的异同。 后缀平衡树并不是一个常见的数据结构名称&#…...
姿态矩阵/旋转矩阵/反对称阵
物理意义,端点矢量角速率叉乘本身向量; 负号是动系b看固定系i是相反的; 一个固定 在惯性导航解算中,旋转矢量的叉乘用于描述姿态矩阵的微分方程。你提到的公式中, ω i b b \boldsymbol{\omega}_{ib}^b \times ωibb…...
【大语言模型】【整合版】DeepSeek 模型提示词学习笔记(散装的可以看我之前的学习笔记,这里只是归纳与总结了一下思路,内容和之前发的差不多)
以下是个人笔记的正文内容: 原文在FlowUs知识库上,如下截图。里面内容和这里一样,知识排版好看一点 一、什么是 DeepSeek 1. DeepSeek 简介 DeepSeek 是一家专注于通用人工智能(AGI)的中国科技公司,主攻大模型研发与…...
ollama无法通过IP:11434访问
目录 1.介绍 2.直接在ollama的当前命令窗口中修改(法1) 3.更改ollama配置文件(法2) 3.1更新配置 3.2重启服务 1.介绍 ollama下载后默认情况下都是直接在本地的11434端口中运行,绑定到127.0.0.1(localhost)&#x…...
⭐算法OJ⭐位操作用法总结+实战指南(C++实现)
位操作在OJ 题目中是一种非常高效的工具,常用于优化时间复杂度和空间复杂度。本文是位操作在 OJ 题目中的主要用法总结,并以 C 实现为例。 相关题目:《C⭐算法OJ⭐Single Number 系列(位操作)》 文章目录 1. 基本位操…...
2.1 用大模型构建新人答疑机器人-大模型ACP模拟题-真题
真题 真题:如何初始化OpenAI客户端 client OpenAI( api_keyos.getenv("DASHSCOPE_API_KEY"), base_url"https://dashscope.aliyuncs.com/compatible-mode/v1", ) AI生成模拟题 一、单选题 (每题5分,共6题ÿ…...
单片机裸机编程-时机管理
对于 RTOS 实时操作系统,我们是通过 TASK(任务)进行底层操作的,这与裸机编程中的函数(fun)类似。不同的任务或函数实现不同的功能,在RTOS中,单片机有信号量、队列等不同任务之间的通…...
Bugku CTF CRYPTO
Bugku CTF CRYPTO 文章目录 Bugku CTF CRYPTO聪明的小羊ok[-<>]散乱的密文.!? 聪明的小羊 描 述: 一只小羊翻过了2个栅栏 fa{fe13f590lg6d46d0d0} 分 析:栅栏密码,分2栏,一个栏里有11个 ①手动解密 f a { f e 1 3 f 5 9 0 l g 6 d 4 …...
【洛谷】【ARC100E】Or Plus Max(高维前缀和)
传送门:Or Plus Max 高维前缀和 题目描述 長さ 2N の整数列 A0, A1, ..., A2N−1 があります。(添字が 0 から始まることに注意) 1 ≤ K ≤ 2N−1 を満たすすべての整数 K について、次の問題を解いてください。 i,j を整数と…...
宿主机的 root 是否等于 Docker 容器的 root?
在 Docker 容器化技术中,宿主机的 root 和 容器的 root 并不完全相同,尽管它们都称作 “root 用户”。这里需要明确的是,Docker 容器与宿主机之间存在隔离机制,容器内的 root 用户和宿主机的 root 用户有一些关键的区别。 1. 宿主…...
SmolLM2:多阶段训练策略优化和高质量数据集,小型语言模型同样可以实现卓越的性能表现
SmolLM2 采用创新的四阶段训练策略,在仅使用 1.7B 参数的情况下,成功挑战了大型语言模型的性能边界: 在 MMLU-Pro 等测试中超越 Qwen2.5-1.5B 近 6 个百分点数学推理能力(GSM8K、MATH)优于 Llama3.2-1B在代码生成和文…...
云原生降本之路:技术创新与应用解析
随着云计算的快速发展,云原生技术已成为企业降低成本、提高效率的重要手段。本文基于腾讯云容器技术专家孟凡杰的PPT内容,深入探讨了云原生技术在降低企业成本方面的应用,包括资源利用现状、成本优化思路、Kubernetes中的资源分配、横向与纵向…...
《Effective Objective-C》阅读笔记(中)
目录 接口与API设计 用前缀避免命名空间冲突 提供“全能初始化方法” 实现description方法 尽量使用不可变对象 使用清晰而协调的命名方式 方法命名 编辑类与协议命名 为私有方法名加前缀 理解OC错误模型 理解NSCopying协议 协议与分类 通过委托与数据源协议进行…...
Hbase客户端API——语句大全
目录 创建表: 插入数据: 删除数据: 修改数据: 查询数据:Get 查询数据:Scan 查询数据:过滤查询 创建表: 检验: 插入数据: 验证 一次多条数据插入 验证&…...
MQ(Message Queue)
目录 MQ(Message Queue)基本概念 为什么要使用消息队列? 使用消息队列有什么缺点? 如何保证消息不丢失?(如何保证消息的可靠性传输?/如何处理消息丢失的问题?) 通用的MQ场景: RabbitMQ如何保证消息不丢失? 生产者丢数据…...
SQL进阶实战技巧:汽车转向次数分析 | 真实场景案例
目录 0 问题描述 1 数据准备 2 问题分析 3 小结 关键技术总结 0 问题描述 现有一组实际汽车在平整路面安全行驶数据,每秒记录一次汽车的车头绝对指向,车头方向记为[0-360)度,部分数据如下,完整数据后附文件。...
青少年软件编程(C语言)等级三级考试试题(2)
Minecraft 题目描述 Minecraft 是一个几乎无所不能的沙盒游戏,玩家可以利用游戏内的各种资源进行创造,搭建自己的世界。 在 Minecraft 中,基本的建筑元素是边长为 1 个单位的立方体,Tony 想用 N 个这种小立方体搭建一个长方体&…...
计算机网络————(三)
前文二 前文一 Websocket协议 是一种存在TCP协议之上的协议 当客户端需要了解服务器是否更新就需要不断给客户端发送请求询问是否更新,这行会造成服务端压力很大 而Websocket相当于服务器一旦更新了就会给客户端发送消息表明自己更新了,类似客户端订阅…...
【音视频】音视频录制、播放原理
一、音视频录制原理 通常,音视频录制的步骤如下图所示: 我们分别从音频和视频开始采样,通过麦克风和摄像头来接受我们的音频信息和图像信息,这通常是同时进行的,不过,通常视频的采集会比音频的采集慢&…...
如何用python将pdf转为text并提取其中的图片
要将 PDF 转为文本并提取其中的图片,可以使用 Python 的几个库来实现: PDF 转文本:使用 PyMuPDF 或 pdfplumber 来提取文本。提取图片:使用 PyMuPDF 或 pdf2image 来提取图像。 以下是实现的步骤和代码示例: 1. 安装…...
deepseek 导出导入模型(docker)
前言 实现导出导入deepseek 模型。deepseek 安装docker下参考 docker 导出模型 实际生产环境建议使用docker-compose.yml进行布局,然后持久化ollama模型数据到本地参考 echo "start ollama" docker start ollama#压缩容器内文件夹,然后拷贝…...
基于Redis 的分布式 session 图解
Redis 分布式 Session 工作原理 1. 传统 Session 的问题 在传统单服务器环境中,HTTP Session 存储在应用服务器的内存中。这在分布式系统中会导致问题: 用户的请求可能被分发到不同服务器,导致会话不一致服务器宕机会导致会话丢失需要依赖…...
Vue进阶之AI智能助手项目(四)——ChatGPT的调用和开发
AI智能助手项目 前端接口部分src/api/index.tssrc/utils/request/index.tspost方法httpHttpOptionsrc/utils/request/axios.tsLayout布局页面-viewsexception异常页面src/views/exception/404/index.vuesrc/views/exception/500/index.vueLayout布局页面src/views/chat/layout/…...
DeepSeek-R1本地部署保姆级教程
一、DeepSeek-R1本地部署配置要求 (一)轻量级模型 ▌DeepSeek-R1-1.5B 内存容量:≥8GB 显卡需求:支持CPU推理(无需独立GPU) 适用场景:本地环境验证测试/Ollama集成调试 (二&a…...
【deepseek】本地部署+webui访问
背景 最近deepseek很火,但是官网的老是被限流使用,还有就是自己也想着玩一玩,于是准备在自己电脑跑一个 直接附上结果地址mydeepseek 准备工作 windows和linux都可 我这里选择linux,ubuntu系统 安装ollama 看下图࿰…...
deepseek部署:ELK + Filebeat + Zookeeper + Kafka
## 1. 概述 本文档旨在指导如何在7台机器上部署ELK(Elasticsearch, Logstash, Kibana)堆栈、Filebeat、Zookeeper和Kafka。该部署方案适用于日志收集、处理和可视化场景。 ## 2. 环境准备 ### 2.1 机器分配 | 机器编号 | 主机名 | IP地址 | 部署组件 |-…...
博客系统笔记总结 2( Linux 相关)
Linux 基本使用和程序部署 基本命令 文件操作 显示当前目录下的文件 ls:显示当前目录下的文件 ll:以列表的形式展示,包括隐藏文件 进入目录 && 显示当前路径 cd:进入目录(后面跟相对路径或者绝对路径&…...
