295

オブジェクトがあり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"
4

14 に答える 14

535

と呼ばれる関数がすでにあります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';
    };

  }());
}

console.log(new Date().toISOString())

于 2011-12-19T15:27:44.850 に答える
64

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
于 2010-04-05T15:55:50.420 に答える
64

:この回答は、2022-03の時点でまだ賛成を得ています。moment.jsライブラリは非推奨になりました。これらは2つの主要な選択肢です:LuxonDay.js、その他は非推奨のリンクで言及されています。

Luxon

LuxonはMomentの進化と考えることができます。これは 、Momentの長年の寄稿者であるIsaacCambronによって作成されました。Luxonが存在する理由をお読みください。LuxonドキュメントのForMomentユーザーページ。

ロケール:Intl提供タイムゾーン:Intl提供

Day.js

Day.jsは、同様のAPIを使用して、Moment.jsの最小限の代替となるように設計されています。これはドロップインの代替ではありませんが、MomentのAPIの使用に慣れていて、すばやく移動したい場合は、Day.jsの使用を検討してください。

ロケール:個別にインポートできるカスタムデータファイルタイムゾーン:プラグインを介して提供されるIntl

サイズの違いからDay.jsを使用していますが、Luxonの方が扱いやすいです。


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

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

私が遭遇した最善の解決策は、Moment.js javascriptライブラリを使用し、次のコードを使用することです。

タイムゾーン情報とミリ秒で現在の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() 

タイムゾーン情報は含まれているがミリ秒は含まれていないネイティブJavaScriptDateオブジェクトのISO時間を取得するには

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

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

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

于 2013-03-08T19:50:01.573 に答える
38

尋ねられた質問は、精度が低下したISO形式でした。出来上がり:

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

末尾のZが必要であると想定し、それ以外の場合は省略します。

于 2014-10-23T13:19:04.033 に答える
17

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

new Date().toJSON()
于 2012-11-08T14:12:56.833 に答える
13

IE7をサポートする必要がない場合は、以下を簡潔に説明します。

console.log(
  JSON.parse(JSON.stringify(new Date()))
)

于 2012-05-03T22:53:46.993 に答える
10

顧客は頭の中で変換を行うのが好きではないので、私は通常、UTC日付を表示したくありません。ローカル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))
};

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

// 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;
}
于 2013-04-23T19:04:38.163 に答える
5

toISOStringの問題は、日時が「Z」としてのみ指定されることです。

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

特に数行のコードで取得できる場合は、このような小さなタスクに別のプラグイン、moment.jsを使用するのは良い考えではないと思います。

時間帯と分単位のタイムゾーンオフセットを取得したら、日時文字列に追加できます。

私はそれにブログ投稿を書きました:http://usefulangle.com/post/30/javascript-get-date-time-with-offset-hours-minutes

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);

于 2017-01-05T10:19:00.423 に答える
3

「T」の後に「+」がありません

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

それをする必要があります。

先行ゼロについては、ここからこれを使用できます:

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)
于 2010-04-04T04:15:16.473 に答える
3
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);
}
于 2016-12-01T09:06:55.443 に答える
2

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

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

出力:

Fri Apr 02 2010 19:42 hrs
于 2017-02-26T04:08:55.193 に答える
1

私はこの小さな拡張機能を次のように使用しますDate-http ://blog.stevenlevithan.com/archives/date-time-format

var date = new Date(msSinceEpoch);
date.format("isoDateTime"); // 2007-06-09T17:46:21
于 2010-04-04T11:05:41.827 に答える
1
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コードゴルフの一部だったと思います)、InternetExplorer10以前でも機能するように改善しました。それは醜いですが、それは仕事を成し遂げます。

于 2015-03-05T15:53:54.357 に答える
0

ショーンの素晴らしく簡潔な答えをいくつかの砂糖と現代の構文で拡張するには:

// 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
于 2018-07-24T10:46:42.310 に答える