一、JS计算时间差

  返回(天、小时、分钟、秒)

var date1= '2015/05/01 00:00:00';  //开始时间,为了浏览器兼容性,最好不要用'2015-05-01 00:00:00'
var date2 = new Date(); //结束时间
var date3 = date2.getTime() - new Date(date1).getTime(); //时间差的毫秒数
var hours = date3 / (3600 * 1000);

二、JS 时间增加后返回时间

增加(天、小时、分钟、秒)

var temp = dateTime.setHours(dateTime.getHours() + 2);

var inDateTimeMin = new Date(temp);

注:dateTime 是时间格式

三、JS中new Date()的浏览器兼容性问题

  引言: 同一种语言javascript,在不同的浏览器中,存在语言兼容性问题,本质上是由于不同的浏览器在支持的语言标准和实现上各有差异。

  以下基于new Date来创建Date对象来分析这个问题。

1.  问题的提出, 开始时间和结束时间控件无法正确的传递值

在页面中,我们使用了一个时间组件来开发时间选择框,但是发现在Firefox下是无法正常工作的,在Chrome下是可以正常运行的。 问题出在哪里呢?

2.  问题分析

结果分析发现是由于如下代码产生的问题:

var timestart = '2010-05-04';
var timeend = '2015-04-01';
var time1 = (timestart+' 00:00:00').toString();
var time2 = (timeend+' 23:59:59').toString();
timestart = new Date(time1);
timeend = new Date(time2);

  问题就在于 new Date(time1)这个构造函数无法正确的生成Date对象,其值为NaN. 怪哉,问题在哪里呢?

3. 各个浏览器上的表现

  在IE下的执行情况:

在Firefox下的执行情况和在Chrome下的执行情况,正常

4. 正确的做法

以下列出正确的做法:

var time1 = (timestart+' 00:00:00').toString();
var time2 = (timeend+' 23:59:59').toString();
timestart = new Date(Date.parse(time1 .replace(/-/g,"/"))).getTime();
timeend = new Date(Date.parse(time2 .replace(/-/g,"/"))).getTime();

主要的变化是对默认的日期格式进行了转换, 基于'/'格式的日期字符串,才是被各个浏览器所广泛支持的,‘-’连接的日期字符串,则是只在chrome下可以正常工作。

5. 知识点总结

'2015-05-04'是无法被各个浏览器中【ie中就不行】,使用new Date(str)来正确生成日期对象的。正确的用法是'2015/05/05'.

实例:

var currentTimes = data.TIME.replace("T", " ");

    currentTimes = new Date(Date.parse(currentTimes.replace(/-/g, "/"))); //兼容IE浏览器

    var nowTimes = new Date().toString('YY/MM/dd/hh/mm/ss');

    nowTimes = new Date(Date.parse(nowTimes.replace(/-/g, "/")));//兼容IE浏览器

四、JS计算两个时间差,按x时x分输出

  场景:停车时长,您的车已经停了5小时25分

var myDate = new Date();//获取系统当前时间

在后台对数据进行json序列化时,如果数据中包含有日期[dateTime],序列化后返回到前端的结果可能是这样的: /Date(1448864369815)/  。

var startTime = Base.getLongTime(row.STARTTIME);   //getLongTime见下文

//如果拿到的不是日期类型,而是"2016-03-28 10:27:00"这种的字符串格式呢,那么就需要先将字符串转换为时间类型

//使用 /代替- 【 '2015-05-04'是无法被各个浏览器中【ie中就不行】,使用new Date(str)来正确生成日期对象的。 正确的用法是'2015/05/05'.】

var d1 = startTime.replace(/\-/g, "/");   // (st.replace("-","/"));

var date1 = new Date(d1);  //时间类型

var diffHour = (parseInt(myDate - date1) / 1000 / 3600) //直接相减是毫秒

return Base.computeHourTime(diffHour);  //computeHourTime见下文

自定义的js方法:

//将/Date(1448864369815)/ 转换为"2016-03-28 10:27:00"
getLongTime: function (nS) {
nS = nS.replace("/Date(", "");
nS = nS.replace(")/", "");
var dt = new Date(parseInt(nS));
var $_year = dt.getFullYear();
var $_month = parseInt(dt.getMonth()) + 1;
if ($_month.toString().length <= 1) {
$_month = "0" + $_month;
}
var $_day = dt.getDate();
if ($_day.toString().length <= 1) {
$_day = "0" + $_day;
}
var $_hours = dt.getHours();
if ($_hours.toString().length <= 1) {
$_hours = "0" + $_hours;
}
var $_minutes = dt.getMinutes();
if ($_minutes.toString().length <= 1) {
$_minutes = "0" + $_minutes;
}
var $_seconds = dt.getSeconds();
if ($_seconds.toString().length <= 1) {
$_seconds = "0" + $_seconds;
}
var $_f_date = $_year + "-" + $_month + "-" + $_day + " " + $_hours + ":" + $_minutes + ":" + $_seconds;
return $_f_date;
}, computeHourTime: function (hour) { //hour是两个时间差 用小时表示,可以为小数
var r = "";
r = this.computeMinTime(hour * 60);
return r;
} computeMinTime: function (min) {
var r = "";
if (min < 0) {
r = "-";
} else if (min == 0) {
r = "0分";
} else {
var m = min % 60;//分
var h = parseInt(min / 60);//时
var d = parseInt(h / 24);//天
h = h - d * 24; if (d != 0) {
r += d + "天";
}
if (h != 0) {
r += h + "时";
}
if (m != 0) {
r += Math.ceil(m) + "分";
}
}
return r;
},

五、JS中比较两个时间的大小

第一种:直接比较大小即可

var st="2009-10-20 14:38:40"
var et="2009-10-20 15:38:40"
if(st>et)
  alert("开始时间必须小于结束时间")

第二种:转换为date对象进行比较操作

var st="2009-10-20 14:38:40"
var et="2009-10-20 15:38:40"
var stdt=new Date(st.replace("-","/"));
var etdt=new Date(et.replace("-","/"));
if(stdt>etdt) alert("开始时间必须小于结束时间")

或者

function compareDate(s1,s2){
return ((new Date(s1.replace(/-/g,"\/")))>(new Date(s2.replace(/-/g,"\/"))));
}

第三种:  对不明时间字符串格式

var curTime = new Date();
//把不明字符串格式 先转换为毫秒数(Date.parse),再转化为日期类
var starttime = new Date(Date.parse(begintime));
var endtime = new Date(Date.pares(endtime));
return (curTime>=starttime && cutTime<=endtime);

六、AngularJS 时间格式化处理

  1、AngularJs的controller中格式:

var dateAsString = $filter('date')(item_date, "yyyy-MM-dd hh:mm:ss");

注意: controller需要注入$filter

  2、 AngularJs的views中格式:

{{item_date | date:'yyyy-MM-dd hh:mm:ss'}}

七、时间字段Json序列化问题

  在后台对数据进行json序列化时,如果数据中包含有日期[dateTime],序列化后返回到前端的结果可能是这样的: /Date(1448864369815)/  。

参考:https://www.cnblogs.com/similar/p/5810304.html

转换1: json时间【‘/Date(1543248000000)/’】转为日期字符串类型,

var jsonToDate = function GetDateFormat(str) {
if (str) {
       return new Date(parseInt(str.substr(6, 13))).toLocaleDateString(); //年月日
}
};

慎用toLocaleDateString【见第八点】。

转换2:时间字符串 转换为时间格式【angularJS中时间过滤必须是datetime格式】

$scope.toDate = function (strDate) {
if (!strDate) {
return new Date();
}
else {
return new Date(strDate);
}
}

注:可以 将angularJS中传递到后台的时间字段 设置为string格式【后台字段】。

这样后台再传回来的时候 也是string格式。。而不会出现json时间格式(/Date(1543248000000)/)  后台需要转为时间的时候再转换。

八、关于toLocaleDateString的坑

  1、Date.toLocaleString()  功能:根据本地时间把Date对象转换为字符串。

语法:DateObject.toLocaleString()

返回值:Date对象的字符串表示,以本地时间区表示,并根据本地规则格式化。

  2、Date.toLocaleDateString()

功能:根据本地时间把Date对象的日期部分转换为字符串。

语法:DateObject.toLocaleDateString()

返回值:Date对象日期部分的字符串表示,以本地时间区表示,并根据本地规则格式化。

  3、Date.toLocaleTimeString()

功能:根据本地时间把Date对象的时间部分转换为字符串。

语法:DateObject.toLocaleTimeString()

返回值:Date对象时间部分的字符串表示,以本地时间区表示,并根据本地规则格式化。

注:时、分、秒字段各占2位数字,如果它们的值小于10,会自动添加前置0。

new Date().toLocaleString()  // "2018/12/6 上午10:26:57"
new Date().toLocaleDateString() //"2018/12/6"
new Date().toLocaleTimeString() //"上午10:33:04"

以下js报错 uncaught TypeError: cannot read property 'length' of undefined.

const dateTransform = date => {

    const tmp = date.split('\/');

    if (tmp[1].length !== 2) {

        tmp[1] = '0' + tmp[1];

    }

    if (tmp[2].length !== 2) {

        tmp[2] = '0' + tmp[2];

    }

    return tmp.join('-');

}

dateTransform(new Date().toLocaleDateString());

看到这段代码瞬间崩溃,怎么用这种方式处理时间显示 ????????????????

姑且认为某猿是加班到凌晨2点写的代码吧(同个物种之间要懂得体谅)。该猿的思路是转换形如"2017/5/12"这样的字符串为"2017-5-12",讲道理可以跑起来的。但是为什昨天的代码,到了今天就无法执行了呢?一定是toLocaleDateString的问题。笔者在firefox中执行了这一段代码,完全正常,但是在chrome中报错。浏览器的问题?

# chrome

console.log(new Date().toLocaleDateString())

> 2017-5-12

#firefox

console.log(new Date().toLocaleDateString())

> 2017/5/12

找到问题了,就是toLocaleDateString的坑。至于为什么昨天能跑,今天不能跑,秒懂啦。chrome升级了。从57升级到了58。

#Chrome < 58

> new Date().toLocaleDateString()

> output: "2017/5/12"

#Chrome >= 58

> new Date().toLocaleDateString()

> output: "2017-5-12"

用moment去实现Date格式化。

后记:首先看看toLocaleDateString是什么东西:

toLocaleDateString() 方法返回该日期对象日期部分的字符串,该字符串格式因不同语言而不同。新增的参数 locales 和 options 使程序能够指定使用哪种语言格式化规则,允许定制该方法的表现(behavior)。

在旧版本浏览器中, locales 和 options 参数被忽略,使用的语言环境和返回的字符串格式是各自独立实现的。

from https://developer.mozilla.org...

这方法最大的问题是在不同的浏览器中得到的结果是不一样的,例如

# firefox
> new Date().toLocaleDateString()
> output: "2017/5/12"
#IE11
> new Date().toLocaleDateString()
> output: "2017-5-12"
 
#Chrome < 58
> new Date().toLocaleDateString()
> output: "2017/5/12"

 
#Chrome >= 58
> new Date().toLocaleDateString()
> output: "2017-5-12"

所以尽可能不要用toLocaleDateString

【JS】时间问题的更多相关文章

  1. js 时间构造函数

    js 时间构造函数,js中没有类似ToString("yyyy-mm-dd HH:mm:ss") 的方法,但是可以用下面的方式来初始化 var cdate = new Date(& ...

  2. js时间倒计时

    看了网上的其他的例子,觉得写的都有点复杂,不好理解,于是自己动手写了个. 本来想封装成jquery插件,但是觉得因为功能很简单,没有必要做成jquery插件,引用的时候不需要引入jqery库,这里直接 ...

  3. js 时间处理

    1.格式化时间 function GetDateTimeFormatter(value) {        if (value == undefined) {            return &q ...

  4. Js 时间与字符串转示例

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  5. js获取当前时间,js时间函数

    Js获取当前日期时间及其它操作,js时间函数 var myDate = new Date(); myDate.getYear(); //获取当前年份(2位) myDate.getFullYear(); ...

  6. js 时间函数 及相关运算大全

    js 时间函数 及相关运算大全 var myDate = new Date(); myDate.getYear();        //获取当前年份(2位) myDate.getFullYear(); ...

  7. js时间过滤方法

    js时间过滤  自己写的  记录一下 /** * * 过滤时间格式 * Created by Catlina at 2019.4.26 */ export const setTime = time = ...

  8. js 时间类函数

    js 时间类是  Date() var currtime = new Date();// 实例一个时间,是当前时间 接收一个时间戳为参数 var time2=new Date(currtime.get ...

  9. js 时间格式化 (兼容safari)

    js 时间格式化,兼容IE8和safari浏览器. function formatDate(date, fmt, near, type) { var dateStr = date; if (!date ...

  10. js时间格式化函数,支持Unix时间戳

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. machine learning相关会议

    1. ICML(International Conference on Machine Learning)   链接:https://en.wikipedia.org/wiki/Internation ...

  2. InnoDB的MVCC实现原理

    InnoDB的MVCC,是通过在每行记录后面保存两个隐藏的列来实现的. 这两个列,一个保存了行的创建时间,一个保存了行的过期时间(删除时间).当然存储的并不是实际时间,而是系统版本号(sytem ve ...

  3. python 操作redis集群

    一.连接redis集群 python的redis库是不支持集群操作的,推荐库:redis-py-cluster,一直在维护.还有一个rediscluster库,看GitHub上已经很久没更新了. 安装 ...

  4. 未能加载文件或程序集system.web.extensions解决方法

    发现未能加载文件或程序集的错误,这是由于我的机器上没有安装Ajax的原因.问题解决后,整理如下:表现:1."System.Web.Extensions, Version=1.0.61025.0, Cu ...

  5. FindWindow SendMessage

    FindWindow 用来根据类名和窗口名来得到窗口句柄的.但是这个函数不能查找子窗口,也不区分大小写. 如果要从一个窗口的子窗口中查找需要使用FindWindowEX. 1.在C#中使用方法如下: ...

  6. 【转载】C#中List集合使用Reverse方法对集合中的元素进行倒序反转

    在C#的List集合操作中,有时候需要对List集合中的元素的顺序进行倒序反转操作,此时就可使用到List集合中的Reverse方法来实现此功能,Reverse方法的签名为void Reverse() ...

  7. a标签中target属性为“_blank”时存在安全问题

    今天看到一个比较有意思的洞,虽然不够严重,但是却普遍存在各大src中 熟悉js的朋友都应该知道当我们在调用window下的open方法创建一个新窗口的同时,我们可以获得一个创建窗口的opener句柄, ...

  8. mysql学习之基础篇05

    mysql中的统计函数: 1. 查询商品价格中最高的价格: select max(shop_price) from goods; 2. 查询商品价格中最低的价格: select min(shop_pr ...

  9. InteiiJ IDEA中如何制定制定哪一个配置文件

    项目下有好些application.property文件 彼此之间也不是什么  从application.property中指定dev就去对应dev的关系 就想用我本地的数据库 于是添加了一个appl ...

  10. 隐藏按钮button

    <td> <input id="del" type="button" value="删除" onclick="u ...