DeepSeek 助力 Vue 开发:打造丝滑的进度条
前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕



目录
- DeepSeek 助力 Vue 开发:打造丝滑的进度条
- 📚前言
- 📚页面效果
- 📚指令输入
- 📚think
- 📘组件代码
- 📘使用说明
- 📘组件属性说明:
- 📘示例
- 📘其他说明
- 📚实际操作
- 📚整理后主要代码
- 📘定义组件 Progress.vue
- 📘调用 ProgressView.vue
- 📚页面效果
- 📚DeepSeek安装地址
📚📗📕📘📖🕮💡📝🗂️✍️🛠️💻🚀🎉🏗️🌐🖼️🔗📊👉🔖⚠️🌟🔐⬇️·正文开始⬇️·🎥😊🎓📩😺🌈🤝🤖📜📋🔍✅🧰❓📄📢📈 🙋0️⃣1️⃣2️⃣3️⃣4️⃣5️⃣6️⃣7️⃣8️⃣9️⃣🔟🆗*️⃣#️⃣
DeepSeek 助力 Vue 开发:打造丝滑的进度条
📚前言
在科技飞速发展的今天,人工智能(AI)无疑是最为耀眼的领域之一。从最初的概念提出到如今广泛应用于各个行业,AI 的发展历程充满了突破与变革,深刻地改变了我们的生活和工作方式。
人工智能的起源可以追溯到 20 世纪中叶,1956 年的达特茅斯会议正式确立了 “人工智能” 这一术语,标志着该领域的诞生。此后,AI 经历了多个发展阶段,包括早期的专家系统、机器学习,以及近年来取得重大突破的深度学习。在深度学习的推动下,AI 在图像识别、语音识别、自然语言处理等领域取得了惊人的成果,如 AlphaGo 战胜围棋世界冠军李世石,智能语音助手在日常生活中的广泛应用等,这些都让人们切实感受到了 AI 的强大力量。
0基础DeepSeek安装步骤
打开搭建好的DeepSeek应用。

进入应用。

📚页面效果

📚指令输入
已经通过npm create vue@latest创建好了基于Vue3的项目,并能正常运行起来,请帮我用 Vue3的组合式API 生成一个 进度条(Progress Bar)功能,所有代码都保存在components下的一个文件夹中。新功能要有num(修改进度条的进度,支持数字输入和百分比输入和分数输入,默认20%)color(自定义颜色,默认#E94242这个颜色)height(自定义,默认4px)
下面是现有目录
vueAndDeepseek/
├── src/ # 源代码目录
│ ├── assets/ # 静态资源
│ │ ├── base.css
│ │ ├── main.css
│ │ └── logo.svg
│ ├── components/ # 组件目录
│ │ ├── HelloWorld.vue
│ │ ├── TheWelcome.vue
│ │ ├── WelcomeItem.vue
│ │ └── icons/
│ ├── router/ # 路由配置
│ │ └── index.js
│ ├── stores/ # Pinia 状态管理
│ │ └── counter.js
│ ├── views/ # 页面组件
│ │ ├── HomeView.vue
│ │ └── AboutView.vue
│ ├── App.vue # 根组件
│ └── main.js # 应用入口
├── public/ # 公共资源目录
├── index.html # HTML 模板
├── package.json # 项目配置
├── vite.config.js # Vite 配置
└── node_modules/ # 依赖包目录
📚think
好,我现在需要帮用户在基于Vue3的项目中使用组合式API生成一个进度条组件。用户已经创建了项目,并且能够正常运行,接下来要实现进度条的功能,同时代码要放在components下的文件夹内。用户提到新功能需要有num、color和height三个属性,分别对应修改进度的数字输入、自定义颜色以及高度,默认值分别是20%、#E94242和4px。
首先,我应该考虑如何在Vue3中使用组合式API来实现这个进度条。组合式API通常意味着使用 ref 和 computed 属性,以及可能的用到用法约束(Use Cases)模式。但因为用户要求生成一个组件,所以我需要将这些逻辑封装在一个可重用的组件中。
接下来,我需要设计这个Progress组件的结构。它应该有三个主要属性:num、color 和 height。为了方便用户输入,我可能会将num设置为双向绑定的,允许用户输入数字、百分比或者分数。我需要考虑如何处理这些输入,并转化为适当的值,比如将百分比和分数转换为小于100的数值。
然后是颜色的自定义功能。color属性可以接受十六进制字符串,默认使用#E94242。为了让用户更直观地选择颜色,我可能会添加一个颜色选择器组件,或者在 UI 中提供输入框,让用户直接输入颜色代码。
高度的设置相对简单,只需将其作为一个数值属性绑定即可。默认为4px,可以通过样式控制其高度。
接下来是组件的显示部分。进度条需要有动态宽度,这可以通过计算num的百分比来实现。当num超过100时,可能需要进行约束或提示用户输入正确范围内的值。
在组件的模板中,我会使用一个 div 来表示整个容器,然后另一个div作为实际的进度条,根据计算的宽度来设置它的宽度,同时添加一些样式,如rounded或者阴影,以增强视觉效果。
为了使组件更易于使用和自定义,我可能还需要提供额外的属性,比如vertical(是否垂直方向),以及class和style属性,这样用户可以根据需求进行样式扩展。此外,可以考虑在组件内部处理数值格式问题,例如自动添加百分号或限制小数位数。
然后,我会将这个Progress.vue文件放置在components目录下,确保其他页面或组件都可以使用它。为了方便用户使用,我还可能提供一个example.vue文件,展示如何在主应用中使用该进度条组件,并说明各个属性的用法。
最后,在生成代码时,我会注意遵循 Vue3 的最佳实践,合理利用组合式API,同时保持代码的简洁和可维护性。测试不同输入情况,如数字、百分比和分数,以及颜色是否正确应用,以及进度条是否按比例显示,是非常重要的。此外,我还会确保默认值被正确设置,以免用户在使用时遇到意外问题。
总结一下,我的步骤是:定义组件属性,处理输入逻辑,计算宽度,创建DOM结构,并提供样式,同时确保组件易于集成和自定义。这样,用户就能根据需求轻松修改进度条的外观和行为了。
好的,我将帮助你创建一个基于 Vue 3 的组合式 API 进度条(Progress Bar)组件,并将其保存在 components 文件夹中。
📘组件代码
<template><div class="progress-container"><div class="progress-bar" :style="{width: `${getPercentage}!important`,height: `${height}px`}"><!-- 可以添加一些额外的样式 --><div class="progress"><!-- 这里可以有更多的内容 --></div></div></div>
</template><script lang="ts">
import { ref, computed } from 'vue'export default defineComponent({name: 'Progress',props: {num: {type: Number,default: 20,validator: (value) => value >= 0 && value <= 100},color: {type: String,default: '#E94242'},height: {type: Number,default: 4}},setup() {const progressRef = ref(num())// 计算百分比数值const getPercentage = computed(() => {if (typeof num === 'number') {return num()} else if (typeof num === 'string' && num.includes('%')) {// 如果是百分比符号,需要进行处理// 例如:num = "55%" ,则转换为55const percentageValue = parseFloat(num.replace('%', ''))return typeof percentageValue === 'number' ? percentageValue : 0} else if (typeof num === 'string' && num.includes('/')) {// 如果是分数符号,例如:"1/2" 对应50%const fractionValue = parseFloat(num.replace('/', ''))return fractionValue * 100 || 0}return 20})// 输入处理函数function num() {let value = num.value// 如果是百分比符号,提取数值部分if (value?.includes('%')) {value = parseFloat(value.replace('%', ''))} else if (value?.includes('/')) {value = parseFloat(value.replace('/', ''))}// 保持在 0 到 100 之间return Math.min(Math.max(value, 0), 100)}return { progressRef, getPercentage }}
})
</script><style lang="postcss">
.progress-container {/* 添加一些默认样式 */
}.progress-bar {/* 根据需要添加其他样式 */background-color: v-bind(color);border-radius: 4px;overflow: hidden;position: relative;height: v-bind(height);
}.progress {/* 这是进度条的实际内容,可以在这里添加更多内容 */height: 100%;background-color: white;transition: width 0.3s ease-in-out;
}
</style>
📘使用说明
将上述组件注册到你的 Vue 应用中,并按照以下方式使用:
<!-- 在 App.vue 中导入 -->
<template><Progress :num="20" :color="'#E94242'" :height="4"/>
</template>
📘组件属性说明:
-
num:进度条的当前数值,可以是数字、百分比(%)或分数(如 “1/2”)。默认值为20。- 如果是百分比符号
%,则会自动提取数值部分(例如"55%"会被解析为55)。 - 如果是分数符号
/,则会将其转换为小数形式(例如"1/2"会被转换为0.5即50%)。
- 如果是百分比符号
-
color:自定义进度条的颜色,使用十六进制格式。默认值为#E94242。 -
height:进度条的高度(在 px 为单位)。默认值为4。
📘示例
-
完整的数值:
<Progress :num="75" /> -
百分比符号:
<Progress :num="'85%'" /> -
分数符号:
<Progress :num="'1/2'" /> <!-- 将被解析为 50% --> -
自定义颜色和高度:
<Progress :num="30" :color="'#00ff00'" :height="8" />
📘其他说明
- 数值会自动被限制在
0到100之间。 - 如果你需要更复杂的行为或样式,可以根据需要扩展组件代码。
希望这个组件能满足你的需求!如果有任何问题,欢迎随时告诉我。
📚实际操作
控制台会有一个 defineComponent的报错
📚整理后主要代码

📘定义组件 Progress.vue
<script setup>
import { computed } from 'vue'const props = defineProps({num: {type: [Number, String],default: 20,validator: (value) => {if (typeof value === 'number') {return value >= 0 && value <= 100}if (typeof value === 'string') {if (value.includes('%')) {const num = parseFloat(value)return !isNaN(num) && num >= 0 && num <= 100}if (value.includes('/')) {const [num, den] = value.split('/').map(Number)return !isNaN(num) && !isNaN(den) && den !== 0 && (num / den) * 100 <= 100}}return false}},color: {type: String,default: '#E94242'},height: {type: [Number, String],default: 4}
})const progress = computed(() => {const val = props.numif (typeof val === 'number') {return Math.min(100, Math.max(0, val))}if (typeof val === 'string') {if (val.includes('%')) {return Math.min(100, Math.max(0, parseFloat(val)))}if (val.includes('/')) {const [num, den] = val.split('/').map(Number)return Math.min(100, Math.max(0, (num / den) * 100))}}return 20
})
</script>
<template><div class="progress" :style="{ height: typeof height === 'number' ? `${height}px` : height}"><divclass="progress-bar":style="{width: `${progress}%`,backgroundColor: color,height: typeof height === 'number' ? `${height}px` : height}"></div></div>
</template>
<style scoped>
.progress {width: 100%;background: #ebeef5;border-radius: 10px;overflow: hidden;
}.progress-bar {transition: width 0.6s ease;
}
</style>
📘调用 ProgressView.vue

<script setup>
import Progress from '../components/Progress/Progress.vue'
</script><template><main><h1>1.直接调用 <code><Progress /></code></h1><Progress/><h1 class="mt10">2. 数字输入, 参数60,是60% <p><code><Progress :num="60"/> </code></p></h1><Progress :num="60"/><h1 class="mt10">3. 带2个参数,改变长度和颜色。<p><code><Progress :num="30" :color="'#41B883'"/> </code></p> </h1><Progress :num="30" :color="'#41B883'"/><h1 class="mt10">4.百分比输入时不加:号 <p><code><Progress num="75%"/> </code></p> </h1><Progress num="75%" /> <!-- 百分比输入 --><h1 class="mt10">5.分数输入时不加:号 <p><code><Progress num="3/4"/> </code></p> </h1><Progress num="3/4"/> <!-- 分数输入 --><h1 class="mt10">6.自定义颜色时不加:号 <p><code><Progress :num="80" color="blue"/> </code></p> </h1><Progress :num="80" color="blue"/> <!-- 自定义颜色 --><h1 class="mt10">7.自定义高度 <p><code><Progress :num="40" :height="8"/> </code></p> </h1><Progress :num="40" :height="8"/> <!-- 自定义高度 --></main>
</template>
<style>
.mt10{margin-top: 10px;
}
</style>
📚页面效果

📚DeepSeek安装地址
蓝耘元生代智算云平台地址:https://cloud.lanyun.net/#/registerPage?promoterCode=07100c37a0
到此这篇文章就介绍到这了,更多精彩内容请关注本人以前的文章或继续浏览下面的文章,创作不易,如果能帮助到大家,希望大家多多支持宝码香车~💕,若转载本文,一定注明本文链接。

更多专栏订阅推荐:
👍 html+css+js 绚丽效果
💕 vue
✈️ Electron
⭐️ js
📝 字符串
✍️ 时间对象(Date())操作
相关文章:
DeepSeek 助力 Vue 开发:打造丝滑的进度条
前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 目录 Deep…...
deepseek的CoT优势、两阶段训练的有效性学习笔记
文章目录 1 DeepSeek的CoT思维链的优势1.2 open-r1的CoT训练数据1.3 ReAct任务与CoT任务适用场景 2 AI推理方向:deepseek与deepmind的两条路线的差异2.1 PRM与ORM的两大学派分支的差异2.2 DeepSeek-R1的两阶段训练概述 1 DeepSeek的CoT思维链的优势 DeepSeek跟之前…...
分享在职同时准备系统分析师和教资考试的时间安排
(在职、时间有限、同时备考系统分析师考试和小学信息技术教资面试),以下是详细的备考计划,确保计划的可行性和通过性。 一、总体安排 时间分配: 每周周末(2天)用于系统分析师考试备考。工作日晚…...
浅谈Java Spring Boot 框架分析和理解
Spring Boot是一个简化Spring开发的框架,它遵循“约定优于配置”的原则,通过内嵌的Tomcat、Jetty或Undertow等容器,使得开发者能够快速构建独立运行的、生产级别的基于Spring框架的应用程序。Spring Boot包含了大量的自动配置功能,…...
【开发心得】CentOS7编译Redis7.4.2打包RPM完整方案
概述 由于最近客户需要解决redis版本升级问题,故而全网寻找安全版本,redis7.4.x版本求而为果,只能自己编译了。 截止发文时间2025-02-12 最新稳定版的redis版本号为7.4.2 Security fixes (CVE-2024-46981) Lua script commands may lead t…...
【网络安全】常见网络协议
1. 网络协议概述 网络协议是网络上两个或多个设备使用的一组规则,用于描述传输顺序和数据结构。网络协议充当数据包中信息附带的指令。这些指令告诉接收设备如何处理数据。协议就像一种通用语言,让世界各地的设备能够相互通信和理解。 尽管网络协议在网…...
电路笔记(元器件):AD 5263数字电位计(暂记)
AD5263 是四通道、15 V、256位数字电位计,可通过SPI/I2C配置具体电平值。 配置模式: W引脚作为电位器的抽头,可在A-B之间调整任意位置的电阻值。也可将W与A(或B)引脚短接,A-W间的电阻总是0欧姆,通过数字接口调整电位器…...
MongoDB 的使用场景
一、内容管理系统 1. 博客平台 文章内容、作者信息、标签、评论等数据结构多样,MongoDB 的无模式特性可轻松应对。比如 WordPress 等博客系统,使用 MongoDB 能灵活存储不同格式和长度的文章内容,以及与文章相关的各种元数据。 2. 新闻网站…...
MongoDB 是什么
MongoDB 是一款文档型数据库,属于 NoSQL 数据库范畴。 一、基本概念 MongoDB 以文档的形式存储数据,文档类似于 JSON 对象,由键值对组成,它以 BSON(Binary JSON)格式存储在磁盘上,这种格式支持…...
Python3操作MongoDB批量upsert
个人博客地址:Python3操作MongoDB批量upsert | 一张假钞的真实世界 代码如下: mongoClient MongoClient(mongodb://172.16.72.213:27017/) opsDb mongoClient.ops azScheduled opsDb.azScheduledFlowbulkOpers [] for flow in scheduledFlows.valu…...
相机模数转换
模拟图像是什么? 模拟图像是指连续变化的图像,它通常来源于现实世界的物理场景,并通过光学系统(如相机镜头)投射到感光介质上。模拟图像是连续的,这意味着它在空间和颜色值上都有无穷的细节。例如…...
C++20 新特性解析
1. 概念(Concepts) 概念是 C++20 引入的一项重要特性,它允许程序员定义类型约束,从而在编译时检查模板参数是否符合某些要求。概念提供了模板参数的限制,使得模板代码更加可读和易于维护。 示例代码: #include <iostream> #include <concepts>// 定义一个…...
C# ManualResetEvent 类 使用详解
总目录 前言 ManualResetEvent 是 C# 中用于线程同步的核心类之一,位于 System.Threading 命名空间下。它的核心功能是通过信号机制控制线程的执行顺序,允许一个或多个线程等待某个信号后再继续运行。与 AutoResetEvent 不同,ManualResetEve…...
动态规划——路径问题②
文章目录 931. 下降路径最小和算法原理代码实现 64. 最小路径和算法原理代码实现 174. 地下城游戏算法原理代码实现 931. 下降路径最小和 题目链接:931. 下降路径最小和 算法原理 状态表示: 经验题目要求:dp[i][j]表示到达[i,j]位置时&…...
ChatGPT macOS 桌面应用让你的编程体验更上一层楼
高效开发必备:ChatGPT macOS 桌面应用亮点盘点 ©作者|Ninja Geek 来源|神州问学 通过 macOS 版 ChatGPT 应用,已经能够更好的和你的生产力工具无缝配合工作。 大概在三四周之前,Anthropic 在 Claude 上推出了一项名为 Computer Use 的功…...
Java持久化之--Spring Data JPA
1、简介 Java持久化技术是Java开发中比较重要的部分,主要用于将对象数据持久化到数据库,或者从数据库中查询数据,简化数据库的CRUD操作。 2、JPA简介 JPA(Java Persistence API)是Java实现ORM(Object Re…...
excel里的函数技巧(持续更新中)
行转列 在 Excel 中,行转列(将一行数据转换为一列,或者将一列数据转换为一行)是一项常见的操作。你可以使用 转置 功能轻松实现这一操作。 TRANSPOSE(数组)...
基于python sanic框架,使用Nacos进行微服务管理
微服务软件系统构建方式,已经很普及了,通过开源的sanic进行微服务管理,便捷,技术也比较成熟,而在项目实际应用过程中,微服务类型不仅有java的,还有nodejs、python等,尤其是结合算法模型构建的python接口,需要在Nacos进行注册管理。本文内容耗时2天踏坑,亲测一切ok。 …...
Day84:数据可视化
数据可视化是数据分析的重要组成部分,它能直观地展现数据规律,使复杂数据变得易懂。Python 提供了多个数据可视化库,其中最常用的是 Matplotlib 和 Seaborn。今天,我们将学习如何使用这些工具绘制折线图、柱状图、散点图等。 1. 安装和导入库 如果你的 Python 没有安装 Ma…...
fetch() 与 XMLHttpRequest 的差异
fetch() 与 XMLHttpRequest 的差异 fetch() 的功能与 XMLHttpRequest 基本相同,都是向服务器发出 HTTP 请求,但有三个主要的差异。 (1)fetch()使用 Promise,不使用回调函数,因此大大简化了写法࿰…...
深入浅出Asp.Net Core MVC应用开发系列-AspNetCore中的日志记录
ASP.NET Core 是一个跨平台的开源框架,用于在 Windows、macOS 或 Linux 上生成基于云的新式 Web 应用。 ASP.NET Core 中的日志记录 .NET 通过 ILogger API 支持高性能结构化日志记录,以帮助监视应用程序行为和诊断问题。 可以通过配置不同的记录提供程…...
Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...
Golang dig框架与GraphQL的完美结合
将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用,可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器,能够帮助开发者更好地管理复杂的依赖关系,而 GraphQL 则是一种用于 API 的查询语言,能够提…...
微信小程序 - 手机震动
一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注:文档 https://developers.weixin.qq…...
成都鼎讯硬核科技!雷达目标与干扰模拟器,以卓越性能制胜电磁频谱战
在现代战争中,电磁频谱已成为继陆、海、空、天之后的 “第五维战场”,雷达作为电磁频谱领域的关键装备,其干扰与抗干扰能力的较量,直接影响着战争的胜负走向。由成都鼎讯科技匠心打造的雷达目标与干扰模拟器,凭借数字射…...
全志A40i android7.1 调试信息打印串口由uart0改为uart3
一,概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本:2014.07; Kernel版本:Linux-3.10; 二,Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01),并让boo…...
sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!
简介 sipsak 是一个面向会话初始协议 (SIP) 应用程序开发人员和管理员的小型命令行工具。它可以用于对 SIP 应用程序和设备进行一些简单的测试。 sipsak 是一款 SIP 压力和诊断实用程序。它通过 sip-uri 向服务器发送 SIP 请求,并检查收到的响应。它以以下模式之一…...
Spring是如何解决Bean的循环依赖:三级缓存机制
1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间互相持有对方引用,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...
FFmpeg:Windows系统小白安装及其使用
一、安装 1.访问官网 Download FFmpeg 2.点击版本目录 3.选择版本点击安装 注意这里选择的是【release buids】,注意左上角标题 例如我安装在目录 F:\FFmpeg 4.解压 5.添加环境变量 把你解压后的bin目录(即exe所在文件夹)加入系统变量…...
微服务通信安全:深入解析mTLS的原理与实践
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、引言:微服务时代的通信安全挑战 随着云原生和微服务架构的普及,服务间的通信安全成为系统设计的核心议题。传统的单体架构中&…...
