Подтвердить что ты не робот

Проблема с функцией Javascript Date в IE 7, возвращает NaN

У меня есть твиттер-канал, и я создаю новую дату, поэтому я могу отформатировать дату по своему вкусу.

var created = new Date(this.created_at) работает в firefox и chrome, но не в IE7. Кажется, у меня проблемы с передачей даты через функцию new Date(). Он просто возвращает undefined и NaN.

Вот код. Если вы попытаетесь проверить это, не забудьте включить jquery. Спасибо.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Twitter Test</title>
<script type="text/javascript" src="jquery-1.4.2.js"></script>
<script type="text/javascript" >

$(function(){
$.getJSON("http://twitter.com/statuses/user_timeline/google.json?count=1&callback=?", function(data){
    $.each(data, function(){
        var created = new Date(this.created_at)
        $("<div></div>").append("<ul><li>Unformatted: " + this.created_at + "</li><li>Formatted: " + created + "</li></ul>").appendTo("body")
    });

})  

})

</script>
</head>

<body>
</body>
</html>
4b9b3361

Ответ 1

Вы хотите убедиться, что дата разобрана как UTC, потому что в противном случае javascript будет интерпретировать ее как дату в вашем локальном часовом поясе.

Дата выглядит следующим образом: Tue Jul 13 23:18:36 +0000 2010

Вы можете разобрать его так:

function parseDate(str) {
  var v=str.split(' ');
  return new Date(Date.parse(v[1]+" "+v[2]+", "+v[5]+" "+v[3]+" UTC"));
} 

Который даст правильную дату/время в локальном часовом поясе, например: Tue Jul 13 2010 19:18:36 GMT-0400 (EDT)

Таким образом, чтобы ваш код выглядел примерно так:

$(function(){
  $.getJSON("http://twitter.com/statuses/user_timeline/google.json?count=1&callback=?", function(data){
    $.each(data, function(){
      var created = parseDate(this.created_at);
      $("<div></div>").append("<ul><li>Unformatted: " + this.created_at + "</li><li>Formatted: " + created + "</li></ul>").appendTo("body");
    });
  });
  function parseDate(str) {
    var v=str.split(' ');
    return new Date(Date.parse(v[1]+" "+v[2]+", "+v[5]+" "+v[3]+" UTC"));
  } 
});

Ответ 2

Я нашел jQuery глобализационный модуль, чтобы работать лучше всего. Другие методы имели проблемы с перекрестным браузером, и такие вещи, как date.js, не обновлялись довольно долго.

Вам также не нужен datePicker на странице. Вы можете просто вызвать что-то похожее на пример, указанный в документах:

$.parseDate('yy-mm-dd', '2007-01-26');

Ответ 3

Вот что я сделал, чтобы исправить это!

$tweetList.append('<p><span class="twitterdate">' + parseTwitterDate(item.created_at) + location + '</span></p>');

var month=new Array();
month[0]="January";
month[1]="February";
month[2]="March";
month[3]="April";
month[4]="May";
month[5]="June";
month[6]="July";
month[7]="August";
month[8]="September";
month[9]="October";
month[10]="November";
month[11]="December";

function parseTwitterDate($stamp) {
    var v=$stamp.split(' ');
    var date = new Date(Date.parse(v[1]+" "+v[2]+", "+v[5]+" "+v[3]+" UTC"));
    var hour = date.getHours();
    var ampm = hour<12 ? ' AM' : ' PM';
    return date.getHours() +':'+ date.getMinutes() +' '+ ampm +' '+ date.getDate() +' '+ month[date.getMonth()] +' '+ date.getFullYear();
}

И это даст мне "19:38 PM 23 апреля 2012" в Chrome, IE и Firefox.