传递给新Date()的正确跨浏览器日期格式是什么

时间:2012-05-20 22:22:45

标签: date cross-browser format

我确实使用了

var elems = $("#D li").toArray();
elems.sort(function(a, b) {
    var adate = new Date($(a).find('div.dateDiv').text());
    var bdate = new Date($(b).find('div.dateDiv').text());
    return adate > bdate ? -1 : 1;
});
$("#D").html(elems);

<div id="D">
    <li>1<div class="dateDiv">2012-04-15 10:25:45</div><div>df</div></li> 
    <li>2 <div class="dateDiv">2012-04-10 19:41:08</div><div>df</div></li> 
    <li> 3 <div class="dateDiv">2012-04-20 07:00:10</div><div>ab</div></li> 
    <li>4 <div class="dateDiv">2012-04-12 16:45:50</div><div>a</div></li>

     <li>1<div class="dateDiv">2012-04-15 10:25:45</div></li>
   <li>2 <div class="dateDiv">2012-04-10 19:41:08</div></li>
  <li> 3 <div class="dateDiv">2012-04-20 07:00:10</div></li>
   <li>4 <div class="dateDiv">2012-04-12 16:45:50</div></li>


      <li>1<div class="dateDiv">2012-04-15 10:25:45</div></li>
   <li>2 <div class="dateDiv">2012-04-10 19:41:08</div></li>
  <li> 3 <div class="dateDiv">2012-04-20 07:00:10</div></li>
   <li>4 <div class="dateDiv">2012-04-12 16:45:50</div></li>


      <li>1<div class="dateDiv">2012-04-15 10:25:45</div></li>
   <li>2 <div class="dateDiv">2012-04-10 19:41:08</div></li>
  <li> 3 <div class="dateDiv">2012-04-20 07:00:10</div></li>
   <li>4 <div class="dateDiv">2012-04-12 16:45:50</div></li>
</div>​

我尝试了很多次 Firefox浏览器或IE或Safari的一些问题

它仅适用于opera和chrome,

传递给新Date()的正确跨浏览器日期格式是什么?

1 个答案:

答案 0 :(得分:0)

如果您可以控制HTML中的日期格式,那么最好将其转换为时间戳。否则,您需要在javascript中创建一个函数,将其转换为正确的格式,无论是什么形式。

不是这样做,为什么不将它拆分成它的部分并将正确的参数传递给新的Date() - 年,月,日,小时,分钟,秒。

http://jsfiddle.net/katylava/xpjRa/2/

function parseDate(date) {
    var date_time = date.split(' ');
    var ymd = date_time[0].split('-');
    var his = date_time[1].split(':');
    return new Date(ymd[0], ymd[1], ymd[2], his[0], his[1], his[2]);
}

var elems = $("#D li").toArray();
elems.sort(function(a, b) {
    var adate = parseDate($(a).find('div.dateDiv').text());
    var bdate = parseDate($(b).find('div.dateDiv').text());
    return adate > bdate ? -1 : 1;
});