html时间选择控件 简书,HTML的时间问题

根据输入框内的时间日期,获得该日期前6天的日期;

52375b44583e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

得到该时间近一周的日期:

52375b44583e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

我原先写了得到前一天的函数:

//计算前一天,使图表地x轴动态显示

function preDay(now){

var l = new Array();

if(now.indexOf("-") >= 0)

var data = now.split("-");

else var data = now.split("/");

var year = data[0];

var month = data[1];

var day = data[2];

var dd = new Date();

var d = new Date(year, month, day);

// console.log(year+"-"+month+"-"+day);

for(var i = 6; i >= 0;i--){

dd.setTime(d.getTime()-24*60*60*1000*i);

var y = dd.getFullYear();

var m = dd.getMonth();

var d2 = dd.getDate();

// console.log(dd+"~"+m);

l.push(([y,m,d2].join('-')));

}

return l;

}

在使用过程中发现,从输入框得到的日期是2017-5-31,但var d = new Date(year, month, day);所创建的日期是2017-6-30,而在var m = dd.getMonth();时得到的月份是5;

但是这样得到的日期就是少一个月的,如我的输入框日期为2017-02-01时,所呈现出的时间是:

52375b44583e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

image.png

解决:

在创建时减少一个月,获取月份时增加一个月;

//计算前一天,使图表地x轴动态显示

function preDay(now){

var l = new Array();

if(now.indexOf("-") >= 0)

var data = now.split("-");

else var data = now.split("/");

var year = data[0];

var month = data[1];

var day = data[2];

var dd = new Date();

var d = new Date(year, month-1, day);

// console.log(year+"-"+month+"-"+day);

for(var i = 6; i >= 0;i--){

dd.setTime(d.getTime()-24*60*60*1000*i);

var y = dd.getFullYear();

var m = dd.getMonth()+1;

var d2 = dd.getDate();

// console.log(dd+"~"+m);

l.push(([y,m,d2].join('-')));

}

return l;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值