时长输入框、用时输入框

时长输入框、用时输入框

行内组件,用于设定 【时 分 秒】 时长,转存结果为 【毫秒】
编辑调用
只读调用

<template><div class="time-inputs"><div class='time-input-div' v-if='input'><input class='time-input' type="number" v-model.number="hours" @input="updateMilliseconds" placeholder="" min='0' /><span class='uom'></span><input class='time-input' type="number" v-model.number="minutes" @input="updateMilliseconds" placeholder="" min='0' /><span class='uom'></span><input class='time-input' type="number" v-model.number="seconds" @input="updateMilliseconds" placeholder="" min='0' /><span class='uom'></span><button @click="resetTime" class="reset-button">置零</button> <!-- 添加置零按钮 --></div><div class='time-input-div' v-else><div class='time-input'>{{hours}}</div><span class='uom'></span><div class='time-input'>{{minutes}}</div><span class='uom'></span><div class='time-input'>{{seconds}}</div><span class='uom'></span></div></div>
</template><script>
export default {props: {// 调用处绑定回写值value: {type: Number,default: 0,required: true,},// 是否输入input: {type: Boolean,default: true,required: false,},},data() {return {hours: 0,minutes: 0,seconds: 0,milliseconds: 0,};},computed: {totalMilliseconds() {return (this.hours * 3600000 +this.minutes * 60000 +this.seconds * 1000 +this.milliseconds);},},watch: {totalMilliseconds(newVal) {this.$emit('input', newVal);},value(newVal) {const total = newVal || 0;this.hours = Math.floor(total / 3600000);this.minutes = Math.floor((total % 3600000) / 60000);this.seconds = Math.floor((total % 60000) / 1000);this.milliseconds = total % 1000;},},mounted() {let that = this;that.value = that.value || 0; // 确保有初始值const total = that.value || 0;that.hours = Math.floor(total / 3600000);that.minutes = Math.floor((total % 3600000) / 60000);that.seconds = Math.floor((total % 60000) / 1000);that.milliseconds = total % 1000;},methods: {resetTime() {this.hours = 0;this.minutes = 0;this.seconds = 0;this.milliseconds = 0;this.updateMilliseconds(); // 更新毫秒数},updateMilliseconds() {// 这里可以根据需要更新毫秒数的逻辑this.milliseconds = this.totalMilliseconds % 1000;},},
};
</script><style scoped>
.time-inputs {display: inline-block;width: 100%;
}
.time-input-div {width: 100%;display: flex;justify-content: space-between;align-items: center;
}
.time-input {display: flex;justify-content: center;align-items: center;width: 50px;height: 30px;border: 1px solid #d7d7d7;border-radius: 5px;text-align: center;transition: border-color 0.3s, box-shadow 0.3s; /* 添加过渡效果 */outline: none; /* 去掉默认的聚焦轮廓 */
}.time-input:focus {border-color: #0044FF; /* 输入框聚焦时边框颜色变为蓝色 */box-shadow: 0 0 5px 1px rgba(40, 97, 255, 0.4); /* 添加发光效果 */
}.uom {margin: 0 5px;
}.reset-button {height: 30px;margin-left: 10px; /* 为按钮添加左边距 */padding: 0 10px; /* 为按钮添加内边距 */background-color: #0043fd; /* 按钮背景颜色 */color: white; /* 按钮文字颜色 */border: none; /* 去掉按钮边框 */border-radius: 5px; /* 按钮圆角 */cursor: pointer; /* 鼠标悬停时显示为手型 */display: flex;justify-content: center;align-items: center;
}.reset-button:hover {background-color: #3d6efc; /* 鼠标悬停时按钮颜色变化 */
}
</style>

编辑调用

<CTimeInputBox v-model:value="model.minLeadtime" style='width: 100%'/>

只读调用

<CTimeInputBox :input='false' v-model:value='text'></CTimeInputBox>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/34522.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

java反射的基础应用

一、堆内存中的情况 &#xff08;一&#xff09;对象创建与变化 源对象&#xff08;UserBo&#xff09;和目标对象&#xff08;User&#xff09; 在执行UserBo sourceObj new UserBo(username, password);和User targetObj new User();时&#xff0c;分别在堆内存中创建了U…

Unity3D常见的设计模式(五)

系列文章目录 unity知识点 文章目录 系列文章目录&#x1f449;前言&#x1f449;一、桥接模式&#xff08;Bridge&#xff09;&#x1f449;二、适配器模式&#xff08;Adapter&#xff09;&#x1f449;三、 外观模式&#xff08;Facade&#xff09;&#x1f449;四、原型模…

车机端同步outlook日历

最近在开发一个车机上的日历助手&#xff0c;其中一个需求就是要实现手机端日历和车机端日历数据的同步。然而这种需求似乎没办法实现&#xff0c;毕竟手机日历是手机厂商自己带的系统应用&#xff0c;根本不能和车机端实现数据同步的。 那么只能去其他公共的平台寻求一些机会&…

群控系统服务端开发模式-应用开发-邮件工厂结构封装

首先在系统根目录下extend文件夹下创建邮件工厂文件夹并更名叫Mail。 一、邮件发送父类 在Mail目录下创建邮件发送父类并更名为MailSenderInterface.php&#xff0c;代码如下 <?php /*** 邮件发送父类* User: 龙哥三年风水* Date: 2024/12/5* Time: 14:22*/ namespace Ma…

React性能优化

三个可以优化的地方 避免过度多次渲染 组件会在以下情况下重新渲染 注意&#xff1a;例如组件组合的形式&#xff0c;<Test><Counter></Counter></Test>,即使Test发生了重新渲染&#xff0c;Counter也不会重新渲染。另外使用React这样的库或框架时&a…

操作系统学习

问题&#xff1a; 因为想用傲梅来给系统盘扩容&#xff0c;导致无法进入操作系统&#xff0c;报错如下&#xff1a; 无法加载应用程序或操作系统&#xff0c;原因是所需文件丢失或包含错误. 文件:Windowslsystem32lwinload.efi错误代码: 0xc000007b 你需要使用恢复工具。如果…

Web应用程序文件包含-Server2233-解析

B-6 Web应用程序文件包含 任务环境说明:服务器场景名称:Server2233

计算机的错误计算(一百七十五)

摘要 就计算机的错误计算&#xff08;一百七十三&#xff09;与&#xff08;一百七十四&#xff09;中案例&#xff0c;讨论其另外一种形式&#xff1a; 的错误计算问题。 例1. 已知 计算 直接贴图吧&#xff1a; 这样&#xff0c;MATLAB的输出中有4位错误数字&#xff0…

F-K变换法

f-k变换实质上是一种二维傅里叶变换。 在时间域上,对一道地震信号做傅里叶变换,可以得到在时间上不同频度(称为频率)的 波动组分的振幅和相位信息。同样地,在空间上,我们也可以对多道地震信号做类似傅里叶变 换的数值变换,得到在空间上不同频度(称为波数)的波动组分的振幅…

webstorm关闭了弹窗 Confirm Exit 恢复回来

webstorm关闭了 Confirm Exit WebStorm 关闭了“Confirm Exit”功能&#xff0c;意味着当用户尝试关闭IDE时&#xff0c;不会显示确认对话框&#xff0c;直接退出程序。 如果你想要恢复这个功能&#xff0c;可以按照以下步骤操作&#xff1a; 打开WebStorm。 进入设置界面&a…

集成学习之-stacking

一、引言 对于单模型来说&#xff0c;模型的抗干扰能力低&#xff0c;且难以拟合复杂的数据。 所以可以集成多个模型的优缺点&#xff0c;提高泛化能力。 集成学习一般有三种&#xff1a;boosting是利用多个弱学习器串行&#xff0c;逐个纠错&#xff0c;构造强学习器。 baggin…

Linux-使用 tslib 库

上一章我们学习了如何编写触摸屏应用程序&#xff0c;包括单点触摸和多点触摸&#xff0c;主要是对读取到的 struct input_event 类型数据进行剖析&#xff0c;得到各个触摸点的坐标。本章向大家介绍 tslib 库&#xff0c;这是 Linux 系统下&#xff0c;专门为触摸屏开发的应用…

SHELL----正则表达式

一、文本搜索工具——grep grep -参数 条件 文件名 其中参数有以下&#xff1a; -i 忽略大小写 -c 统计匹配的行数 -v 取反&#xff0c;不显示匹配的行 -w 匹配单词 -E 等价于 egrep &#xff0c;即启用扩展正则表达式 -n 显示行号 -rl 将指定目录内的文件打…

[Redis#15] 持久化 | AOF | rewrite | aof_buf | 混合持久化

目录 1 使用AOF 流程 问题一&#xff1a;父进程在fork之后继续写旧AOF文件的意义 问题二&#xff1a;执行BGREWRITEAOF时的特殊情况处理 2 命令写入 3 文件同步 4 重写机制 工作流程&#xff1a; 触发条件 混合持久化 持久化 sum AOF&#xff08;Append Only File&a…

重生之我在异世界学智力题(1)

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言智力题题目&#xff1a;《奇怪的时钟…

【WRF后处理】WRF时区(UTC)需转化为北京时间(CST)!!!

目录 WRF运行时间标准注意事项-本地时区问题 输入数据&#xff1a;ERA5时间标准ERA5数据和WRF模型需要转换为北京时间&#xff01;&#xff01;&#xff01;北京时间&#xff08;CST&#xff09;与协调世界时&#xff08;UTC&#xff09;的关系转换方法 参考 WRF运行时间标准 …

css怎么使页面高度占满屏幕?

下面是一个小程序的页面&#xff0c;用uniapp写的&#xff0c;现在有一个问题&#xff0c;就是最外层的allmy的图层&#xff0c;屏幕是灰色&#xff0c;我怎么才能使这个图层占满屏幕&#xff0c;就是让灰色占满屏幕。 直接先给page设置一个height:100%;然后allmy的height:100%…

K8S离线部署Nacos集群【Oracle作外部数据源】

一、前言 由于公司的要求下要使Nacos集群以Oracle作为外部数据源&#xff0c;前期咱们已经阐述了如何在本地搭建&#xff08;Nacos集群搭建【Oracle作外部数据源】&#xff09;&#xff0c;本次将带领大家在k8s上部署Nacos集群并以Oracle作为外部数据源。 二、软件包 nacos-f…

Halcon 深度学习目标分类:原理与应用全解析

摘要&#xff1a; 本文深入探讨了 Halcon 在深度学习目标分类方面的原理及广泛的应用场景。详细阐述了从数据准备到模型训练与分类决策的目标分类工作流程&#xff0c;剖析了其背后的深度学习技术支撑。同时&#xff0c;结合多个行业领域&#xff0c;展示了 Halcon 目标分类技术…

【burp】burpsuite基础(五)

Burp Suite基础&#xff08;五&#xff09; 声明&#xff1a;该笔记为up主 泷羽的课程笔记&#xff0c;本节链接指路。 警告&#xff1a;本教程仅作学习用途&#xff0c;若有用于非法行为的&#xff0c;概不负责。 抓包方式 burp在抓包上十分全面&#xff0c;这里介绍几种抓包…