js计算两个日期之差天数总是不正确


做了一个时间倒计时,发现天数总是不正确。

js代码:

//定义目标日期
var targetTime = new Date();

//目标日期
targetTime.setFullYear(2015,5,1);

//目标时
targetTime.setHours(12);

//目标分
targetTime.setMinutes(0);

//目标秒
targetTime.setSeconds(0);

//目标毫秒
targetTime.setMilliseconds(0);

//转为毫秒数
var EndTime = targetTime.getTime();  

//定义方法
function GetCountDownTime() {
       
            //定义参数返回当天的日期和时间
            var NowTime = new Date();
            
            //得出时间毫秒差
            var CountDownMS = EndTime - NowTime.getTime();
            
            //得出时间天数差
            var CountDownDays = Math.floor(CountDownMS / (1000 * 60 * 60 * 24 ));

            //得出时间小时差
            var CountDownH = Math.floor(CountDownMS / (1000 * 60 * 60)) % 24;

            //得出时间分钟差
            var CountDownM = Math.floor(CountDownMS / (1000 * 60)) % 60;

            //得出时间秒数差
            var CountDownS = Math.floor(CountDownMS / 1000) % 60;
            }
        } 


$(document).ready(function () {
            window.setInterval("GetCountDownTime()", 1000);
        });

在计算得出的天数中,倒计时总是与定义的目标日期相差30天左右

//目标日期 targetTime.setFullYear(2015,5,1);

问题出在这:

js计算两个日期之差天数总是不正确

setFullYear()方法的三个参数year,month,day;其中的month表示月份的数值是介于0~11之间。  所以目标日期2015年5月1日应该是

//目标日期 targetTime.setFullYear(2015,4,1);

所以月份month参数为实际月份-1。基础不牢被坑的真惨!

相关阅读 >>

js获取html元素的实际宽度高度的方法

javascript获取当前日期

js如何实现利用键盘控制div移动

js 中 9 个强大主流写法(各种 hack 写法)

js如何设置css

详解js中switch语句的使用方法

js如何实现蒙版效果

js怎么将字符串转为数组?

关于js中的blob对象类型的详细介绍

vue 轻量级图表组件

更多相关阅读请进入《js》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...