web-dev-qa-db-ja.com

ISO 8601形式の文字列をJavaScriptで出力するにはどうすればいいですか?

Dateオブジェクトがあります。 次のスニペットのtitle部分をレンダリングするにはどうすればよいですか?

<abbr title="2010-04-02T14:12:07">A couple days ago</abbr>

私は他の図書館からの「相対的な時間」の部分を持っています。

私は以下を試しました:

function isoDate(msSinceEpoch) {

   var d = new Date(msSinceEpoch);
   return d.getUTCFullYear() + '-' + (d.getUTCMonth() + 1) + '-' + d.getUTCDate() + 'T' +
          d.getUTCHours() + ':' + d.getUTCMinutes() + ':' + d.getUTCSeconds();

}

しかしそれは私に与えます:

"2010-4-2T3:19"
239
James A. Rosen

すでに toISOString() という関数があります。

var date = new Date();
date.toISOString(); //"2011-12-19T15:28:46.493Z"

どういうわけか、それがサポートされていない ブラウザ なら、私はあなたがカバーしてもらった:

if ( !Date.prototype.toISOString ) {
  ( function() {

    function pad(number) {
      var r = String(number);
      if ( r.length === 1 ) {
        r = '0' + r;
      }
      return r;
    }

    Date.prototype.toISOString = function() {
      return this.getUTCFullYear()
        + '-' + pad( this.getUTCMonth() + 1 )
        + '-' + pad( this.getUTCDate() )
        + 'T' + pad( this.getUTCHours() )
        + ':' + pad( this.getUTCMinutes() )
        + ':' + pad( this.getUTCSeconds() )
        + '.' + String( (this.getUTCMilliseconds()/1000).toFixed(3) ).slice( 2, 5 )
        + 'Z';
    };

  }() );
}
429
Anatoly Mironov

ページの最後の例を参照してください https://developer.mozilla.org/en/Core_JavaScript_1.5_Reference:Global_Objects:Date

/* Use a function for the exact format desired... */
function ISODateString(d) {
    function pad(n) {return n<10 ? '0'+n : n}
    return d.getUTCFullYear()+'-'
         + pad(d.getUTCMonth()+1)+'-'
         + pad(d.getUTCDate())+'T'
         + pad(d.getUTCHours())+':'
         + pad(d.getUTCMinutes())+':'
         + pad(d.getUTCSeconds())+'Z'
}

var d = new Date();
console.log(ISODateString(d)); // Prints something like 2009-09-28T19:03:12Z
63

Web上のほとんどすべてのto-ISOメソッドは、文字列を出力する前に "Z"に変換することでタイムゾーン情報を削除します(UTC)。ブラウザのネイティブの.toISOString()もタイムゾーン情報を削除します。

サーバや受信者は、常に完全なISO日付をZulu時間または必要な時間帯に変換しながら、送信者の時間帯情報を取得できるため、貴重な情報は破棄されます。

私が遭遇した最良の解決策は、Moment.jsjavascriptライブラリを使うことです。次のコードを使用してください。

タイムゾーン情報とミリ秒を使用して現在のISO時刻を取得する

now = moment().format("YYYY-MM-DDTHH:mm:ss.SSSZZ")
// "2013-03-08T20:11:11.234+0100"

now = moment().utc().format("YYYY-MM-DDTHH:mm:ss.SSSZZ")
// "2013-03-08T19:11:11.234+0000"

now = moment().utc().format("YYYY-MM-DDTHH:mm:ss") + "Z"
// "2013-03-08T19:11:11Z" <- better use the native .toISOString() 

タイムゾーン情報を含むがミリ秒なしでネイティブのJavaScript DateオブジェクトのISO時刻を取得する

var current_time = Date.now();
moment(current_time).format("YYYY-MM-DDTHH:mm:ssZZ")

これをDate.jsと組み合わせてDate.today()のような関数を取得し、その結果をすぐに渡すことができます。

このようにフォーマットされた日付文字列はJSONに準拠しており、データベースに格納するのに適しています。 PythonとC#はそれが好きそうです。

59
Daniel F

質問された質問はISOフォーマットwith精度の低下でした。 Voila:

 new Date().toISOString().slice(0, 19) + 'Z'
 // '2014-10-23T13:18:06Z'

末尾のZが必要であると仮定し、そうでなければ単に省略します。

24
arcseldon

あなたがIE7をサポートする必要がないならば、以下は素晴らしい、簡潔なハックです:

JSON.parse(JSON.stringify(new Date()))
11
Russell Davis

最短ですが、Internet Explorer 8以前ではサポートされていません。

new Date().toJSON()
10
younes0

顧客は自分の頭の中で変換を行うのが好きではないので、通常はUTCの日付を表示したくありません。 local ISOの日付を表示するには、関数を使います。

function toLocalIsoString(date, includeSeconds) {
    function pad(n) { return n < 10 ? '0' + n : n }
    var localIsoString = date.getFullYear() + '-'
        + pad(date.getMonth() + 1) + '-'
        + pad(date.getDate()) + 'T'
        + pad(date.getHours()) + ':'
        + pad(date.getMinutes()) + ':'
        + pad(date.getSeconds());
    if(date.getTimezoneOffset() == 0) localIsoString += 'Z';
    return localIsoString;
};

上記の関数はタイムゾーンのオフセット情報を省略しています(現地時間がUTCである場合を除く)。そのため、私は以下の関数を使用してローカルオフセットを単一の場所で表示します。毎回オフセットを表示したい場合は、上記の関数の結果にその出力を追加することもできます。

function getOffsetFromUTC() {
    var offset = new Date().getTimezoneOffset();
    return ((offset < 0 ? '+' : '-')
        + pad(Math.abs(offset / 60), 2)
        + ':'
        + pad(Math.abs(offset % 60), 2))
};

toLocalIsoStringpadを使用します。必要に応じて、ほぼすべてのパッド機能と同じように機能しますが、完全を期すために、これを使用します。

// Pad a number to length using padChar
function pad(number, length, padChar) {
    if (typeof length === 'undefined') length = 2;
    if (typeof padChar === 'undefined') padChar = '0';
    var str = "" + number;
    while (str.length < length) {
        str = padChar + str;
    }
    return str;
}
6
Charles Burns

ToISOStringの問題はdatetimeを "Z"としてしか与えないことです。

ISO-8601では、2016-07-16T19:20:30 + 5:30(タイムゾーンがUTCより進んでいる場合)および2016-07-16T19:20:30-01のような形式で、時間帯と時間帯でのタイムゾーンの違いを含む日時も定義されています:00(タイムゾーンがUTCより遅い場合).

このような小さな作業には、特に数行のコードで入手できる場合は、別のプラグイン、moment.jsを使用することはお勧めできません。



    var timezone_offset_min = new Date().getTimezoneOffset(),
        offset_hrs = parseInt(Math.abs(timezone_offset_min/60)),
        offset_min = Math.abs(timezone_offset_min%60),
        timezone_standard;

    if(offset_hrs < 10)
        offset_hrs = '0' + offset_hrs;

    if(offset_min > 10)
        offset_min = '0' + offset_min;

    // getTimezoneOffset returns an offset which is positive if the local timezone is behind UTC and vice-versa.
    // So add an opposite sign to the offset
    // If offset is 0, it means timezone is UTC
    if(timezone_offset_min < 0)
        timezone_standard = '+' + offset_hrs + ':' + offset_min;
    else if(timezone_offset_min > 0)
        timezone_standard = '-' + offset_hrs + ':' + offset_min;
    else if(timezone_offset_min == 0)
        timezone_standard = 'Z';

    // Timezone difference in hours and minutes
    // String such as +5:30 or -6:00 or Z
    console.log(timezone_standard); 


時間帯を時間と分でオフセットしたら、datetime文字列を追加できます。

私はそれについてのブログ記事を書いた: http://usefulangle.com/post/30/javascript-get-date-time-with-offset-hours-minutes

3
Useful Angle
function timeStr(d) { 
  return ''+
    d.getFullYear()+
    ('0'+(d.getMonth()+1)).slice(-2)+
    ('0'+d.getDate()).slice(-2)+
    ('0'+d.getHours()).slice(-2)+
    ('0'+d.getMinutes()).slice(-2)+
    ('0'+d.getSeconds()).slice(-2);
}
3
Sean

'T'の後に '+'がありません

isoDate: function(msSinceEpoch) {
  var d = new Date(msSinceEpoch);
  return d.getUTCFullYear() + '-' + (d.getUTCMonth() + 1) + '-' + d.getUTCDate() + 'T'
         + d.getUTCHours() + ':' + d.getUTCMinutes() + ':' + d.getUTCSeconds();
}

それをするべきです。

先行ゼロの場合は、これを here から使用できます。

function PadDigits(n, totalDigits) 
{ 
    n = n.toString(); 
    var pd = ''; 
    if (totalDigits > n.length) 
    { 
        for (i=0; i < (totalDigits-n.length); i++) 
        { 
            pd += '0'; 
        } 
    } 
    return pd + n.toString(); 
} 

このように使う:

PadDigits(d.getUTCHours(),2)
3
kaiz.net

私はちょうどDateにこの小さな拡張子を使うでしょう - http://blog.stevenlevithan.com/archives/date-time-format

var date = new Date(msSinceEpoch);
date.format("isoDateTime"); // 2007-06-09T17:46:21
2
Anurag

私は非常に少ないコードで出力を下回ることができました。

var ps = new Date('2010-04-02T14:12:07')  ;
ps = ps.toDateString() + " " + ps.getHours() + ":"+ ps.getMinutes() + " hrs";

出力:

Fri Apr 02 2010 19:42 hrs
2
function getdatetime() {
    d = new Date();
    return (1e3-~d.getUTCMonth()*10+d.toUTCString()+1e3+d/1)
        .replace(/1(..)..*?(\d+)\D+(\d+).(\S+).*(...)/,'$3-$1-$2T$4.$5Z')
        .replace(/-(\d)T/,'-0$1T');
}

私はどこかでStack Overflowの基本を見つけました(私はそれが他のStack Exchangeコードゴルフィングの一部であると信じています)、そしてそれがInternet Explorer 10またはそれ以前のバージョンでも動作するように私はそれを改良しました。それは醜いです、しかしそれは仕事をやり遂げます。

0
Jonas Byström

Seanのすばらしい簡潔な答えを、砂糖と現代の構文で拡張するには、次のようにします。

// date.js

const getMonthName = (num) => {
  const months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Oct', 'Nov', 'Dec'];
  return months[num];
};

const formatDate = (d) => {
  const date = new Date(d);
  const year = date.getFullYear();
  const month = getMonthName(date.getMonth());
  const day = ('0' + date.getDate()).slice(-2);
  const hour = ('0' + date.getHours()).slice(-2);
  const minutes = ('0' + date.getMinutes()).slice(-2);

  return `${year} ${month} ${day}, ${hour}:${minutes}`;
};

module.exports = formatDate;

それから例えば。

import formatDate = require('./date');

const myDate = "2018-07-24T13:44:46.493Z"; // Actual value from wherever, eg. MongoDB date
console.log(formatDate(myDate)); // 2018 Jul 24, 13:44
0
Juha Untinen