JS中有哪些常见的日期操作,怎样实现
Admin 2022-06-23 群英技术资讯 1095 次浏览
很多朋友都对“JS中有哪些常见的日期操作,怎样实现”的内容比较感兴趣,对此小编整理了相关的知识分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获,那么感兴趣的朋友就继续往下看吧!let Utils = {
/**
* 是否为闫年
* @return {Boolse} true|false
*/
isLeapYear: function(y) {
return (y % 4 == 0 && y % 100 != 0) || y % 400 == 0;
},
/**
* 返回星期数
* @return {Number}
*/
getWhatDay: function(year, month, day) {
let date = new Date(year + '/' + month + '/' + day);
let index = date.getDay();
let dayNames = ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'];
return dayNames[index];
},
/**
* 返回星期数
* @return {Number}
*/
getMonthPreDay: function(year, month) {
let date = new Date(year + '/' + month + '/01');
let day = date.getDay();
if (day == 0) {
day = 7;
}
return day;
},
/**
* 返回月份天数
* @return {Number}
*/
getMonthDays: function(year, month) {
if (/^0/.test(month)) {
month = month.split('')[1];
}
return [0, 31, this.isLeapYear(year) ? 29 : 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month];
},
/**
* 补齐数字位数
* @return {string}
*/
getNumTwoBit: function(n) {
n = Number(n);
return (n > 9 ? '' : '0') + n;
},
/**
* 日期对象转成字符串
* @return {string}
*/
date2Str: function(date, split) {
if (typeof date == 'string') return date;
split = split || '-';
let y = date.getFullYear();
let m = this.getNumTwoBit(date.getMonth() + 1);
let d = this.getNumTwoBit(date.getDate());
return [y, m, d].join(split);
},
/**
* 返回日期格式字符串
* @param {Number} 0返回今天的日期、1返回明天的日期,2返回后天得日期,依次类推
* @return {string} '2014-12-31'
*/
getDay: function(i) {
i = i || 0;
let date = new Date();
let diff = i * (1000 * 60 * 60 * 24);
date = new Date(date.getTime() + diff);
return this.date2Str(date);
},
/**
* 时间戳转换为日期格式
* @return {String}
*/
timestampToDate: function(timestamp) {
let date = new Date(timestamp);
return date.getFullYear() + '-' + getNumTwoBit(date.getMonth() + 1) + '-' + getNumTwoBit(date.getDate());
},
/**
* 时间比较
* @return {Boolean}
*/
compareDate: function(date1, date2) {
let startTime = new Date(date1.replace('-', '/').replace('-', '/'));
let endTime = new Date(date2.replace('-', '/').replace('-', '/'));
if (startTime >= endTime) {
return false;
}
return true;
},
/**
* 时间比较
* @return {Boolean}
*/
compareDateArr: function(date1, date2) {
let startTime = new Date();
startTime.setFullYear(parseInt(date1[0]), parseInt(date1[1]) - 1, parseInt(date1[2]));
startTime.setHours(parseInt(date1[3]), parseInt(date1[4]));
let endTime = new Date();
endTime.setFullYear(parseInt(date2[0]), parseInt(date2[1]) - 1, parseInt(date2[2]));
endTime.setHours(parseInt(date2[3]), parseInt(date2[4]));
if (startTime >= endTime) {
return false;
}
return true;
},
/**
* 时间是否相等
* @return {Boolean}
*/
isEqual: function(date1, date2) {
let startTime = new Date(date1).getTime();
let endTime = new Date(date2).getTime();
if (startTime == endTime) {
return true;
}
return false;
},
getDateArr(str) {
return [this.getYear(str), this.getMonth(str), this.getDate(str), this.getHour(str), this.getMinute(str)];
},
isDateString(str) {
return /\d{4}(\-|\/|.)\d{1,2}\1\d{1,2}/.test(str) || /^([01][0-9]|2[0-3])(:[0-5][0-9]){1,2}$/.test(str);
},
getYear(value) {
return this.isDateString(value) ? value.split(' ')[0].split(/-|\/|\./)[0] : value.getFullYear();
},
getMonth(value) {
return this.isDateString(value) ? value.split(' ')[0].split(/-|\/|\./)[1] : value.getMonth() + 1;
},
getDate(value) {
return this.isDateString(value) ? value.split(' ')[0].split(/-|\/|\./)[2] : value.getDate();
},
getHour(value) {
if (this.isDateString(value)) {
const str = value.split(' ')[1] || '00:00:00';
return str.split(':')[0];
}
return value.getHours();
},
getMinute(value) {
if (this.isDateString(value)) {
const str = value.split(' ')[1] || '00:00:00';
return str.split(':')[1];
}
return value.getMinutes();
}
};
export default Utils;
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
TypeScript对于Duck类型和模块命名空间应用 目录 一.TypeScript 鸭子类型 二.TypeScript 命名空间 三.TypeScript 模块 四.类型脚本声明文件 一.TypeScript 鸭子类型 Duck类型是一种动态类型和多态形式.在这种风格中,对象的有效语义不是通过从特定类继承或实现特定接口来确定的,而是通过“当前方法和属性的集合”来确定的. var object_name = { key1: "value1", // 标量 key2: "value", key3: functi ...
今天给大家分享的是用vue怎样实现表格自定义列的效果,如果是做crm系统的朋友,应该常会遇到这样的需求,也就是用户可以按设置好的字段自定义排序或显示或隐藏表格的列,接下来我们详细了解看看这是怎样实现的吧。
跨域指浏览器不允许当前页面的所在的源去请求另一个源的数据,下面这篇文章主要给大家介绍了关于VUE跨域详解以及常用解决跨域的方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
js中!的用法是比较灵活的,它除了做逻辑运算常常会用!做类型判断,可以用!与上对象来求得一个布尔值,
作为原型和原型链的基础,先了解清楚构造函数以及它的执行过程才能更好地帮助我们学习原型和原型链的知识。本篇文章带大家详细了解一下JavaScript中的构造函数,介绍一下怎么利用构造函数创建一个js对象,希望对大家有所帮助!
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008