您的位置 首页 java

JavaScript|日期格式化、今天、昨天、明天和某天

uniapp中的日历组件需要用到开始时间和结束时间,这个时间是字符串形式的,如’2021-01-21’。

组件网址:

需求

我的需求是得到7天前到现在日期的字符串形式,即

 startDate: '2021-11-04'',
endDate: '2021-11-11',  

上代码:

 Date. prototype .format = function(fmt) {
var o = {
"M+": this.getMonth() + 1, //月份 
"d+": this.getDate(), //日 
"h+": this.getHours(), //小时 
"m+": this.getMinutes(), //分 
"s+": this.getSeconds(), //秒 
"q+":  Math.floor ((this.getMonth() + 3) / 3), //季度 
"S": this.getMilliseconds() //毫秒 
};
if (/(y+)/.test(fmt)) {
fmt = fmt. replace (RegExp.$1, (this.getFullYear() + ""). substr (4 - RegExp.$1.length));
}
for (var k in o) {
if (new RegExp("(" + k + ")").test(fmt)) {
fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k])
.length)));
}
}
return fmt;
}
//N天时间戳,时间戳指从1970-01-01 0点开始到某天的毫秒数
function  timestamp (days) {
return days * 24 * 60 * 60 * 1000
}

//几天前,一般以现在的时间为基准,参数默认值老的浏览器可能不支持。
function days_ago(day, base_time = Date.now()) {
return new Date(base_time - timestamp(day))
}
//最常用的今天、昨天、明天,返回时间戳
function  yesterday (){
return days_ago(1)
}
function tomorrow(){
return days_ago(-1)
}
function today(){
return new Date()
}

///字符串格式化的日期,英文常用,如2021-01-01
function en_format(func){
return func.format('yyyy-MM-dd')
}
function en_today(){
return en_format(today())
}
function en_yesterday(){
return en_format(days_ago(1))
}
function en_tomorrow(){
return en_format(days_ago(-1))
}

function cn_format(func){
return func.format('yyyy年MM月dd日')
}
//中文版今天,如2020年02月22日
function cn_today(){
return cn_format(today())
}
//中文版昨天,如1949年10月01日
function cn_yesterday(){
return cn_format(days_ago(1))
}
//中文版明天,如2035年09月09日
function cn_tomorrow(){
return cn_format(days_ago(-1))
}  

使用方法

 cn_today()
'2021年11月10日'
cn_tomorrow()
'2021年11月11日'
cn_yesterday()
'2021年11月09日'
    
en_today()
'2021-11-10'
en_tomorrow()
'2021-11-11'
en_yesterday()
'2021-11-09'  

7天前

 en_format(days_ago(7))
'2021-11-03'  

代码还能再精简,不过于我是已经够用了。

文章来源:智云一二三科技

文章标题:JavaScript|日期格式化、今天、昨天、明天和某天

文章地址:https://www.zhihuclub.com/181600.shtml

关于作者: 智云科技

热门文章

网站地图