格式化日期与moment.js

War*_*arz 231 javascript date-parsing momentjs

我有一个这种格式的字符串:

var testDate = "Fri Apr 12 2013 19:08:55 GMT-0500 (CDT)"

我想使用moment.js以这种格式mm/dd/yyyy : 04/12/2013显示它.

我尝试使用这种方法,

moment(testDate,'mm/dd/yyyy');
Run Code Online (Sandbox Code Playgroud)

哪个错误并说there is no such method called replace?我是以错误的方式接近这个吗?

编辑:

我还要提一下,我正在使用为meteor.js打包的预打包版本的moment.js

Object [object Date] has no method 'replace' : The Exact error from the console
Run Code Online (Sandbox Code Playgroud)

堆栈跟踪:

 at makeDateFromStringAndFormat (http://127.0.0.1:3000/packages/moment/lib/moment/moment.js?b4e3ac4a3d0794023a4410e7941c3e179398b5b0:539:29)
    at moment (http://127.0.0.1:3000/packages/moment/lib/moment/moment.js?b4e3ac4a3d0794023a4410e7941c3e179398b5b0:652:24)
    at populateProfileForEdit (http://127.0.0.1:3000/client/views/home/administration/directory/profiles/profiles.js?acfff908a6a099f37312f62892a22b40f82e5e0f:147:25)
    at Object.Template.profile_personal.rendered (http://127.0.0.1:3000/client/views/home/administration/directory/profiles/profiles.js?acfff908a6a099f37312f62892a22b40f82e5e0f:130:13)
    at Spark.createLandmark.rendered (http://127.0.0.1:3000/packages/templating/deftemplate.js?b622653d121262e50a80be772bf5b1e55ab33881:126:42)
    at http://127.0.0.1:3000/packages/spark/spark.js?45c746f38023ceb80745f4b4280457e15f058bbc:384:32
    at Array.forEach (native)
    at Function._.each._.forEach (http://127.0.0.1:3000/packages/underscore/underscore.js?867d3653d53e9c7a171483edbcad9670e12288c7:79:11)
    at http://127.0.0.1:3000/packages/spark/spark.js?45c746f38023ceb80745f4b4280457e15f058bbc:382:7
    at _.extend.flush (http://127.0.0.1:3000/packages/deps/deps.js?9642a93ae1f8ffa8eb1c2475b198c764f183d693:231:11) 
Run Code Online (Sandbox Code Playgroud)

Jon*_*ski 527

第二个参数moment()解析格式而不是显示格式.

为此,您需要以下.format()方法:

moment(testDate).format('MM/DD/YYYY');
Run Code Online (Sandbox Code Playgroud)

还要注意案例确实很重要.对于Month,Day和Year,格式应为大写.


Aka*_*lya 43

包括moment.js并使用以下代码,您可以格式化您的日期

var formatDate= 1399919400000;

var responseDate = moment(formatDate).format('DD/MM/YYYY');
Run Code Online (Sandbox Code Playgroud)

我的输出是"13/05/2014"

  • @ArslanTariq你可以使用`momentObject.valueOf()`从epoch获得毫秒. (2认同)

小智 25

moment().format();                                // "2019-08-12T17:52:17-05:00" (ISO 8601, no fractional seconds)
moment().format("dddd, MMMM Do YYYY, h:mm:ss a"); // "Monday, August 12th 2019, 5:52:00 pm"
moment().format("ddd, hA");                       // "Mon, 5PM"
Run Code Online (Sandbox Code Playgroud)

  • 如果您解释此代码*如何*解决OP的问题,将会有所帮助。 (2认同)

Sha*_*pta 15

var moment = require('moment');

let yourdate = '2021-01-02T07:57:45.121Z'; // for example

moment(yourdate).format('MM/DD/YYYY');

// output : 01-02-2021


moment(yourdate).format('DD-MMM-YYYY');

// output : 01-Jan-2021
Run Code Online (Sandbox Code Playgroud)


t_d*_*m93 9

你可能不再需要 Moment.js

Moment 是一个很好的时间操作库,但它被认为是一个遗留项目,团队建议使用其他

date-fns是最好的轻量级库之一,它是模块化的,因此您可以选择所需的功能并减少包大小(issue & statement)。

另一个反对在现代应用程序中使用 Moment 的常见论点是它的大小。Moment 不适用于现代“摇树”算法,因此它往往会增加 Web 应用程序包的大小。

import { format } from 'date-fns' // 21K (gzipped: 5.8K)
import moment from 'moment' // 292.3K (gzipped: 71.6K)
Run Code Online (Sandbox Code Playgroud)

格式化日期date-fns

// moment.js
moment().format('MM/DD/YYYY');
// => "12/18/2020"

// date-fns
import { format } from 'date-fns'
format(new Date(), 'MM/dd/yyyy');
// => "12/18/2020"
Run Code Online (Sandbox Code Playgroud)

关于备忘单的更多信息,其中包含可用于替换 moment.js 的函数列表:You-Dont-Need-Momentjs


Kam*_*ski 7

对于从输出日期使用format. 第二时刻参数用于解析 - 但是,如果省略它,testDate则会导致弃用警告

弃用警告:提供的值不是公认的 RFC2822 或 ISO 格式...

var testDate= "Fri Apr 12 2013 19:08:55 GMT-0500 (CDT)"

let s= moment(testDate).format('MM/DD/YYYY');

msg.innerText= s;
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.24.0/moment.min.js"></script>

<div id="msg"></div>
Run Code Online (Sandbox Code Playgroud)

要忽略此警告,您应该提供解析格式

var testDate= "Fri Apr 12 2013 19:08:55 GMT-0500 (CDT)"

let s= moment(testDate, 'ddd MMM D YYYY HH:mm:ss ZZ').format('MM/DD/YYYY');

console.log(s);
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.24.0/moment.min.js"></script>
Run Code Online (Sandbox Code Playgroud)


Dun*_*unc 5

您可以将“L”传递给format处理国际化的方法......

moment.locale('en-US');
moment().format("L");
> "06/23/2021"

moment.locale('fr');
moment().format("L");
> "23/06/2021"
Run Code Online (Sandbox Code Playgroud)

其他长日期格式(fr区域设置):

LT : 'HH:mm',
LTS : 'HH:mm:ss',
L : 'DD/MM/YYYY',
LL : 'D MMMM YYYY',
LLL : 'D MMMM YYYY HH:mm',
LLLL : 'dddd D MMMM YYYY HH:mm'
Run Code Online (Sandbox Code Playgroud)

文档: https: //momentjs.com/docs/#/displaying/format/(请参阅“本地化格式”)