【Vue】vue如何将秒数转成“时分秒”格式

简介: 【Vue】vue如何将秒数转成“时分秒”格式

今天给大家分享一下vue如何将秒数转成“时分秒”格式的相关知识点,可能还有一部分人都还不太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获。

一、使用原生JS的Date库

在Vue.js中,将时间格式化成所需的字符串是一个较为普遍的需求。在这里,我们可以利用JavaScript原生的Date库来实现。

具体步骤如下:

  1. 将秒数转换成毫秒数

首先,我们需要将给定的秒数转化成毫秒数,这可以通过乘以1000来实现。

let time = 1485; // 1485秒
let ms = time * 1000; // 1485000毫秒
  1. 构造Date对象

然后,我们可以使用Date构造函数来创建一个新的Date实例。

let time = 1485; // 1485秒
let ms = time * 1000; // 1485000毫秒
let date = new Date(ms);
  1. 格式化时间

最后,我们可以使用Date原型上的方法来格式化时间,例如使用 getFullYear() 方法获取年份, getMonth() 方法获取月份, getDay() 方法获取日期等等。

对于将秒数转换为时分秒格式,我们可以如下实现:

let time = 1485; // 1485秒
let ms = time * 1000; // 1485000毫秒
let date = new Date(ms);
// 注意这里是使用的getUTCHours()方法,转换成UTC(协调世界时)时间的小时
let hour = date.getUTCHours(); 
// let hour = date.getHours(); 如果直接使用getHours()方法,则得到的时分秒格式会多出来8个小时(在国内开发基本都是使用的是东八区时间),getHours()方法会把当前的时区给加上。
let minute = date.getMinutes();
let second = date.getSeconds();
let formatTime = `${hour.toString().padStart(2, '0')}:${minute.toString().padStart(2, '0')}:${second.toString().padStart(2, '0')}`;
console.log(formatTime); // "00:24:45"

在上面的例子中,我们通过 getUTCHours()、getMinutes()和getSeconds() 方法获取到时间的小时数、分钟数和秒数,并使用 padStart() 函数来将它们设置成两位数。

二、使用day.js

Day.js是一种轻量级的JavaScript日期解析和格式化库,它非常适合在Vue.js的项目中进行快速开发。

使用Day.js来格式化时间非常简单,我们可以通过以下步骤来实现:

  1. 安装Day.js

首先,在Vue.js项目中安装Day.js。可以使用npm包管理器进行安装:

npm install dayjs

或者使用CDN方式引入Day.js的库文件:

<script src="https://cdn.jsdelivr.net/npm/dayjs"></script>
  1. 导入Day.js

Vue.js组件中导入Day.js,并将它绑定到组件的data中:

import dayjs from 'dayjs';
export default {
  data() {
    return {
      dayjs: dayjs,
      time: 1485
    };
  }
}
  1. 格式化时间

最后,我们可以通过Day.js提供的 format() 函数来格式化时间。

<template>
  <div>
    {{dayjs(time * 1000).format('HH:mm:ss')}}
  </div>
</template>

在上面的例子中,我们通过dayjs函数创建了一个Day.js实例,将需要格式化的时间作为其构造函数的参数,并使用 format() 函数将其转换成所需的格式(在这里是“HH:mm:ss”)。

三、拓展

vue前台需要用户能看得懂的时间格式如常见的“2023-04-27 12:02:35”,但是后台数据库则需要时间格式如 LocalDateTime(“2021-04-27T12:02:35”)或者Date类型的,如果数据不经过处理,直接显示,肯定可读性差。

下边就介绍一下前台vue处理方式,就是在vue项目的 main.js 中创建一个过滤器,把时间格式化处理。

Vue.filter('dataFormat', function (originVal) {
  const dt = new Date(originVal)
  const y = dt.getFullYear()
  const m = (dt.getMonth() + 1 + '').padStart(2, '0')
  const d = (dt.getDate() + '').padStart(2, '0')
  const hh = (dt.getHours() + '').padStart(2, '0')
  const mm = (dt.getMinutes() + '').padStart(2, '0')
  const ss = (dt.getSeconds() + '').padStart(2, '0')
  // yyyy-mm-dd hh:mm:ss
  return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
})

在需要进行格式化处理的地方直接引用即可,此处以 elementui 中的表格引用为例

<el-table-column label="使用有效期">
    <template slot-scope="scope">{{scope.row.beginTime | dataFormat}}</template>
</el-table-column>

本文完结!


相关文章
|
3月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
311 2
|
2月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
290 137
|
6月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
787 0
|
6月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
5月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
415 1
|
5月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
260 0
|
6月前
|
JavaScript 前端开发 UED
Vue 表情包输入组件实现代码及详细开发流程解析
这是一篇关于 Vue 表情包输入组件的使用方法与封装指南的文章。通过安装依赖、全局注册和局部使用,可以快速集成表情包功能到 Vue 项目中。文章还详细介绍了组件的封装实现、高级配置(如自定义表情列表、主题定制、动画效果和懒加载)以及完整集成示例。开发者可根据需求扩展功能,例如 GIF 搜索或自定义表情上传,提升用户体验。资源链接提供进一步学习材料。
276 1
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1233 0
|
8月前
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
1019 4
|
7月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
838 77