9

API から取得した日付を再フォーマットしようとしています。私が持っているオブジェクトで:

created_at: "2013-06-13T16:29:55.245Z"

日付を 2013 年 6 月 13 日として表示したいと思います。誰かが私に moment.js の使用を提案しました。たくさんのドキュメントがありますが、使い方が少しわかりません。誰かがこれを行うためのより簡単な方法を助けたり提案したりできますか?

4

4 に答える 4

8

元の文字列を変更する必要はありません。次のように使用できます。

alert(moment("2013-06-13T16:29:55.245Z").format("M/DD/YYYY"));

うまく機能します:http://jsfiddle.net/K5ub8/2/

于 2013-06-13T18:00:44.883 に答える
4

すぐにこれを行うことができます

var timeStr = "2013-06-13T16:29:55.245Z",
    newFormat = moment(timeStr).format('M/DD/YYYY');

document.body.textContent = newFormat;
<script src="https://rawgithub.com/timrwood/moment/2.9.0/min/moment.min.js"></script>

出力

6/13/2013 

瞬間がなく、new Dateオブジェクトではなく純粋な文字列操作を使用すると、次のことができます

var timeStr = "2013-06-13T16:29:55.245Z",
    temp = timeStr.split("T")[0].split("-").reverse(),
    newFormat;

temp[0] = temp.splice(1, 1, temp[0])[0];
newFormat = temp.join("/");
if (newFormat.charAt(0) === "0") {
  newFormat = newFormat.slice(1);
}

document.body.textContent = newFormat;

出力

6/13/2013 

Dateオブジェクトを使用して@ Antony answerを参照してください。回答を削除しました

または、オブジェクトとのクロスブラウザー互換性を高める必要があるDateが、それでも文字列の解析が必要な場合。

var timeStr = "2013-06-13T16:29:55.245Z",
    intermediate = timeStr.split("T"),
    newStr = intermediate[0].split("-").join("/") + " " + intermediate[1].split(".")[0] + " GMT",
    newDate = new Date(newStr),
    newFormat = (1 + newDate.getUTCMonth()) + "/" + newDate.getUTCDate() + "/" + newDate.getFullYear();

document.body.textContent = newFormat;

出力

6/13/2013 

最後に、文字列の解析を行わDate.UTCせるのではなく、文字列を構成要素に分割し、これらの引数を使用してフィードすることができます。Date

Date.UTC(年、月、日 [、時、分、秒、ミリ秒]);

これで、人々がmoment.jsの使用を推奨する理由がわかったかもしれませんが、知識がある限り、ライブラリなしで自分でそれを行うのはそれほど苦痛ではありません。

于 2013-06-13T18:05:14.477 に答える
1

多分あなたは分割を使うことができます

var tuple = createdAt.split("T");
var date = tuple[0];
var dateTuple = date.split("-");
var day = parseInt(dateTuple[2]);
var month = parseInt(dateTuple[1]);
var year = parseInt(dateTuple[0]);
var newFormatedDate = [ month , day,  year ].join("/");
于 2013-06-13T17:55:29.617 に答える
-1

この Format Time API を確認できます - https://www.mashape.com/parsify/format#!endpoint-Time

あなたの日付を「2013-06-13T16:29:55.245Z」と入力したところ、次のような応答がありました -

{
  "given": "2013-06-13T16:29:55.245Z",
  "time": {
  "daysInMonth": 30,
  "millisecond": 245,
  "second": 55,
  "minute": 29,
  "hour": 16,
  "date": 13,
  "day": 4,
  "week": 24,
  "month": 5,
  "year": 2013,
  "zone": "+0000"
 },
  "formatted": {
  "weekday": "Thursday",
  "month": "June",
  "ago": "2 hours",
  "calendar": "Today at 4:29 PM",
  "generic": "2013-06-13T16:29:55+00:00",
  "time": "4:29 PM",
  "short": "06/13/2013",
  "slim": "6/13/2013",
  "hand": "Jun 13 2013",
  "handTime": "Jun 13 2013 4:29 PM",
  "longhand": "June 13 2013",
  "longhandTime": "June 13 2013 4:29 PM",
  "full": "Thursday, June 13 2013 4:29 PM",
  "fullSlim": "Thu, Jun 13 2013 4:29 PM"
 },
  "array": [
   2013,
   5,
   13,
   16,
   29,
   55,
   245
  ],
 "offset": 1371140995245,
 "unix": 1371140995,
 "utc": "2013-06-13T16:29:55.245Z",
 "valid": true,
 "integer": false,
 "zone": 0
}
于 2013-06-13T18:29:12.717 に答える