vue日期时间工具类详解

作者:谈谈的心情 时间:2024-06-07 16:06:22 

最近做的一个项目对日期时间的处理比较多,最后整理到一个工具类里面,方便以后使用:

1. 在utils文件夹下新建一个dateTimeUtil.js文件:

// 获取当前时间并格式化
export function getCurrentTime(){
? var date = new Date()
? var month = date.getMonth() + 1
? var day = date.getDate()
? if (month <= 9) {
? ? month = '0' + month
? }
? if (day <= 9) {
? ? day = '0' + day
? }
? return date.getFullYear() + '-' + month + '-' + day + ' ?' + date.getHours() + ':' + date.getMinutes() + ':' + date.getSeconds()
}
?
// 时间格式化
export function formatTime(v) {
? var date = new Date(v)
? var month = date.getMonth() + 1
? var day = date.getDate()
? if (month <= 9) {
? ? month = '0' + month
? }
? if (day <= 9) {
? ? day = '0' + day
? }
? return date.getFullYear() + '-' + month + '-' + day + ' ?' + date.getHours() + ':' + date.getMinutes() + ':' + date.getSeconds()
}
?
// 日期格式化
export function formatDate(v) {
? var date = new Date(v)
? var month = date.getMonth() + 1
? var day = date.getDate()
? if (month <= 9) {
? ? month = '0' + month
? }
? if (day <= 9) {
? ? day = '0' + day
? }
? return date.getFullYear() + '-' + month + '-' + day
}
?
// 获取前、后n天 https://www.cnblogs.com/aoqizhonghua/p/11775982.html
export function getRangeDate(num, time){
? let n = num;
? let d = '';
? if (time) {
? ? d = new Date(time);
? } else {
? ? d = new Date();
? }
? let year = d.getFullYear();
? let mon = d.getMonth() + 1;
? let day = d.getDate();
? if(day <= n) {
? ? ? if(mon > 1) {
? ? ? ? ? mon = mon - 1;
? ? ? } else {
? ? ? ? ? year = year - 1;
? ? ? ? ? mon = 12;
? ? ? }
? }
? d.setDate(d.getDate() - n);
? year = d.getFullYear();
? mon = d.getMonth() + 1;
? day = d.getDate();
? let s = year + "-" + (mon < 10 ? ('0' + mon) : mon) + "-" + (day < 10 ? ('0' + day) : day);
? return s;
}
?
//获取某个月的起始、终止日期
export function getMonthDate(y, m){
? let start = new Date(y, m-1, 1)
? let year = start.getFullYear();
? let mon = start.getMonth() + 1;
? let day = start.getDate();
? let startDate = year + "-" + (mon < 10 ? ('0' + mon) : mon) + "-" + (day < 10 ? ('0' + day) : day)
?
? let end = new Date((new Date(y, m, 0).getTime() + 24*60*60*1000)-1)
? let year1 = end.getFullYear();
? let mon1 = end.getMonth() + 1;
? let day1 = end.getDate();
? let endDate = year1 + "-" + (mon1 < 10 ? ('0' + mon1) : mon1) + "-" + (day1 < 10 ? ('0' + day1) : day1)
?
? return startDate + ' —— ' + endDate
}
?
/*
? 当前日期是年的第几周
? date1是当前日期
? date2是当年第一天
? d是当前日期是今年第多少天
? 用d + 当前年的第一天的周差距的和在除以7就是本年第几周
*/
export function getYearWeek(a, b, c){
? var date1 = new Date(a, parseInt(b) - 1, c),
? ? ? date2 = new Date(a, 0, 1),
? ? ? d = Math.round((date1.valueOf() - date2.valueOf()) / 86400000)
? ? ??
? return Math.ceil((d + ((date2.getDay() + 1) - 1)) / 7)
}
?
// 计算某年某周的日期范围 https://blog.csdn.net/lyhuo/article/details/82661063
export function weekGetDate(year, weeks){
? var date = new Date(year, "0", "1")
? var time = date.getTime() // 获取当前星期几,0:星期一 ? ??
? var _week = date.getDay() ? ?//当这一年的1月1日为周日时则本年有54周,否则没有54周,没有则去除第54周的提示 ? ?
? if(_week!=0){//一年53周情况
? ? if(weeks==54){
? ? ? return '-1' //今年没有54周
? ? } ? ?
? ? var cnt=0// 获取距离周末的天数 ? ?
? ? if(_week==0){
? ? ? cnt = 7 ?
? ? }else if(_week==1){
? ? ? cnt = 6 ?
? ? }else if(_week==2){ ??
? ? ? cnt = 5
? ? }else if(_week==3){ ??
? ? ? cnt = 4
? ? }else if(_week==4){ ? ?
? ? ? cnt = 3
? ? }else if(_week==5){ ? ?
? ? ? cnt = 2
? ? }else if(_week==6){ ? ?
? ? ? cnt = 1
? ? } ? ?
? ? cnt += 1//加1表示以星期一为一周的第一天 ? ?// 将这个长整形时间加上第N周的时间偏移 ? ?
? ? time += cnt*24*3600000 //第2周开始时间?
? ? var nextYear = new Date(parseInt(year,10)+1,"0","1") ?
? ? var nextWeek = nextYear.getDay()
? ? var lastcnt = 0//获取最后一周开始时间到周末的天数 ? ?
? ? if(nextWeek==0){ ? ?
? ? ? lastcnt = 6 ?
? ? }else if(nextWeek==1){ ? ?
? ? ? lastcnt = 0?
? ? }else if(nextWeek==2){ ? ?
? ? ? lastcnt = 1?
? ? }else if(nextWeek==3){?
? ? ? lastcnt = 2?
? ? }else if(nextWeek==4){ ? ?
? ? ? lastcnt = 3?
? ? }else if(nextWeek==5){ ? ?
? ? ? lastcnt = 4?
? ? }else if(nextWeek==6){ ? ?
? ? ? lastcnt = 5
? ? } ? ?
? ? if(weeks==1){//第1周特殊处理 ? ?// 为日期对象 date 重新设置成时间 time
? ? ? // var start = date.Format("yyyy-MM-dd");
? ? ? var start = date.toLocaleDateString().split('/').join('-')
? ? ? date.setTime(time-24*3600000)
? ? ? var end = date.toLocaleDateString().split('/').join('-')
? ? ? return start + "-----" + end
? ? }else if(weeks==53){//第53周特殊处理 ? ?
? ? ? var start = time+(weeks-2)*7*24*3600000 //第53周开始时间 ? ?
? ? ? var end = time+(weeks-2)*7*24*3600000 + lastcnt*24*3600000 - 24*3600000 //第53周结束时间
? ? ? date.setTime(start)
? ? ? // var _start = date.Format("yyyy-MM-dd");
? ? ? var _start = date.toLocaleDateString().split('/').join('-')
? ? ? date.setTime(end)
? ? ? // var _end = date.Format("yyyy-MM-dd");
? ? ? var _end = date.toLocaleDateString().split('/').join('-')
? ? ? return _start + "---" ?+ _end
? ? }else{ ? ?
? ? ? var start = time+(weeks-2)*7*24*3600000 //第n周开始时间 ? ?
? ? ? var end = time+(weeks-1)*7*24*3600000 - 24*3600000 //第n周结束时间
? ? ? date.setTime(start)
? ? ? // var _start = date.Format("yyyy-MM-dd");
? ? ? var _start = date.toLocaleDateString().split('/').join('-')
? ? ? date.setTime(end)
? ? ? // var _end = date.Format("yyyy-MM-dd");
? ? ? var _end = date.toLocaleDateString().split('/').join('-')
? ? ? return _start + "---" ?+ _end
? ? }?
? }else{//一年54周情况 ? ?
? ? var cnt=0// 获取距离周末的天数 ? ?
? ? if(_week==0 && weeks==1){//第一周 ? ?
? ? ? cnt = 0 ?
? ? }else if(_week==0){ ? ?
? ? ? cnt = 7?
? ? }else if(_week==1){ ? ?
? ? ? cnt = 6 ??
? ? }else if(_week==2){ ? ?
? ? ? cnt = 5?
? ? }else if(_week==3){ ? ?
? ? ? cnt = 4 ?
? ? }else if(_week==4){ ? ?
? ? ? cnt = 3
? ? }else if(_week==5){ ? ?
? ? ? cnt = 2 ?
? ? }else if(_week==6){ ? ?
? ? ? cnt = 1 ?
? ? } ? ?
? ? cnt += 1//加1表示以星期一为一周的第一天 ? ?
? ? // 将这个长整形时间加上第N周的时间偏移 ? ?
? ? time += 24*3600000 //第2周开始时间 ? ?
? ? var nextYear = new Date(parseInt(year,10)+1,"0","1") ??
? ? var nextWeek = nextYear.getDay() ??
? ? var lastcnt = 0 //获取最后一周开始时间到周末的天数 ? ?
? ? if(nextWeek==0){ ? ?
? ? ? lastcnt = 6
? ? }else if(nextWeek==1){ ? ?
? ? ? lastcnt = 0 ? ?
? ? }else if(nextWeek==2){?
? ? ? lastcnt = 1
? ? }else if(nextWeek==3){ ? ?
? ? ? lastcnt = 2
? ? }else if(nextWeek==4){ ? ?
? ? ? lastcnt = 3 ??
? ? }else if(nextWeek==5){ ? ?
? ? ? lastcnt = 4 ??
? ? }else if(nextWeek==6){ ? ?
? ? ? lastcnt = 5?
? ? } ? ?
? ? if(weeks==1){//第1周特殊处理
? ? ? // var start = date.Format("yyyy-MM-dd");
? ? ? var start = date.toLocaleDateString().split('/').join('-')
? ? ? date.setTime(time-24*3600000)
? ? ? alert(start +'--'+ date)
? ? ? return _start + "---" ?+ date
? ? }else if(weeks==54){//第54周特殊处理 ? ?
? ? ? var start = time+(weeks-2)*7*24*3600000 //第54周开始时间 ? ?
? ? ? var end = time+(weeks-2)*7*24*3600000 + lastcnt*24*3600000 - 24*3600000 //第53周结束时间
? ? ? date.setTime(start)
? ? ? // var _start = date.Format("yyyy-MM-dd");?
? ? ? var _start = date.toLocaleDateString().split('/').join('-')
? ? ? date.setTime(end)
? ? ? // var _end = date.Format("yyyy-MM-dd");
? ? ? var _end = date.toLocaleDateString().split('/').join('-')
? ? ? return _start + "---" ?+ _end
? ? }else{ ? ?
? ? ? var start = time+(weeks-2)*7*24*3600000 //第n周开始时间 ? ?
? ? ? var end = time+(weeks-1)*7*24*3600000 - 24*3600000 //第n周结束时间
? ? ? date.setTime(start)
? ? ? // var _start = date.Format("yyyy-MM-dd");
? ? ? var _start = date.toLocaleDateString().split('/').join('-')
? ? ? date.setTime(end)
? ? ? // var _end = date.Format("yyyy-MM-dd");
? ? ? var _end = date.toLocaleDateString().split('/').join('-')
? ? ? return _start + "---" ?+ _end
? ? } ? ?
? } ? ?
}
?
// 计算某年某月的日期范围
export function monthGetDate(year, months) {
? var year = year
? var month = months
? month = month < 10 ? "0" + month: month
? var firstday = year + "-" + month + "-" + "01"
? var lastday = ""
? if (month == "01" || month == "03" || month == "05" || month == "07" || month == "08" || month == "10" || month == "12") {
? ? lastday = year + "-" + month + "-" + 31
? } else if (month == "02") {
? ? if ((year % 4 == 0 && year % 100 != 0) || (year % 100 == 0 && year % 400 == 0)) {
? ? ? lastday = year + "-" + month + "-" + 29
? ? } else {
? ? ? lastday = year + "-" + month + "-" + 28
? ? }
? } else {
? ? lastday = year + "-" + month + "-" + 30
? }
? return firstday + '---' + lastday
}
?
//生成随机字符串方法
export function getString() {
? let time = new Date()
? time = time.getTime()
?
? return `${Math.random().toString(36).substr(2, 10)}${time}`
}
?
//升序排序
export function bubbleSortUp(arr, flag) {
? for (var i = 0; i < arr.length; i++) {
? ? for (var j = 0; j < arr.length - i - 1; j++) {
? ? ? if (arr[j][flag] > arr[j + 1][flag]) {
? ? ? ? var c = arr[j];
? ? ? ? arr[j] = arr[j + 1];
? ? ? ? arr[j + 1] = c;
? ? ? }
? ? }
? }
?
? return arr;
}
?
//降序排序
export function bubbleSortDown(arr, flag) {
? for (var i = 0; i < arr.length; i++) {
? ? for (var j = 0; j < arr.length - i - 1; j++) {
? ? ? if (arr[j][flag] < arr[j + 1][flag]) {
? ? ? ? var c = arr[j + 1];
? ? ? ? arr[j + 1] = arr[j];
? ? ? ? arr[j] = c;
? ? ? }
? ? }
? }
?
? return arr;
}
?
//减法精度处理
export function floatSub(arg1, arg2) {
? var r1, r2, m, n;
? try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }
? try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
? m = Math.pow(10, Math.max(r1, r2));
? n = (r1 >= r2) ? r1 : r2;
?
? return ((arg1 * m - arg2 * m) / m).toFixed(n);
}

2. 在需要的文件中引入使用:

vue日期时间工具类详解

获取七天前的日期:

let day7 = util.getRangeDate(7)

来源:https://blog.csdn.net/ljw124213/article/details/124297637

标签:vue,时间,日期
0
投稿

猜你喜欢

  • Vue使用Swiper的案例详解

    2024-04-26 17:39:01
  • java数据库操作类演示实例分享(java连接数据库)

    2024-01-28 03:30:20
  • 教你一步步利用python实现贪吃蛇游戏

    2023-09-21 13:23:27
  • Python进阶之如何快速将变量插入有序数组

    2021-07-26 16:52:51
  • python使用opencv实现马赛克效果示例

    2022-10-16 04:23:30
  • 提升Python程序运行效率的6个方法

    2023-08-23 08:36:46
  • 详解eslint在vue中如何使用

    2023-07-02 16:58:58
  • Python实现简易五子棋游戏

    2023-02-04 07:02:22
  • python将多个py文件和其他文件打包为exe可执行文件

    2021-07-02 05:36:40
  • JS实现密码框根据焦点的获取与失去控制文字的消失与显示效果

    2024-04-10 10:50:20
  • Python实现Keras搭建神经网络训练分类模型教程

    2023-08-06 12:33:03
  • 教你使用Python提取视频中的美女图片

    2021-05-21 22:41:50
  • PHP操作数组的一些函数整理介绍

    2023-11-24 14:24:17
  • 分组字符合并SQL语句 按某字段合并字符串之一(简单合并)

    2024-01-24 11:30:20
  • Jupyter加载文件的实现方法

    2021-11-12 23:16:15
  • python数字图像处理实现直方图与均衡化

    2021-04-01 14:44:59
  • python点云地面点滤波(Progressive Morphological Filter)算法介绍(PCL库)

    2021-12-23 00:38:29
  • Python操作Access数据库基本步骤分析

    2024-01-18 22:32:20
  • 解决tensorflow由于未初始化变量而导致的错误问题

    2023-06-05 17:44:05
  • 使用SqlServer CTE递归查询处理树、图和层次结构

    2024-01-16 07:35:42
  • asp之家 网络编程 m.aspxhome.com