Упакованное решение: Luxon
Если вы хотите использовать одно решение для всех, я настоятельно рекомендую использовать Luxon (модернизированная версия Moment.js ), который также выполняет форматирование во многих локалях / языках и множество других функций.
Luxon размещен на веб-сайте Moment.js и разработан разработчиком Moment.js, поскольку Moment.js имеетограничения, которые разработчик хотел бы устранить, но не смог.
Для установки:
npm install luxon
или yarn add luxon
(см. ссылку для других способов установки)
Пример:
luxon.DateTime.fromISO('2010-08-10').toFormat('yyyy-LLL-dd');
Выход:
10 августа 2010 года
Ручное решение
Используя форматирование, аналогичное Moment.js, Класс DateTimeFormatter (Java) и Класс SimpleDateFormat (Java) , я реализовал комплексное решение formatDate(date, patternStr)
, где код простчитать и изменять.Вы можете отобразить дату, время, AM / PM и т. Д. См. Код для дополнительных примеров.
Пример:
formatDate(new Date(), 'EEEE, MMMM d, yyyy HH:mm:ss:S')
(formatDate
реализовано вфрагмент кода ниже)
Выход:
Пятница, 12 октября 2018 г. 18: 11: 23: 445
Попробуйте ввести код, нажав "Фрагмент кода выполнения. "
Шаблоны даты и времени
yy
= год из двух цифр;yyyy
= полный год
M
= цифровой месяц;MM
= двухзначный месяц;MMM
= короткое название месяца;MMMM
= полное название месяца
EEEE
= полное название дня недели;EEE
= короткое название дня недели
d
= день цифры;dd
= день, состоящий из двух цифр
h
= часы / час;hh
= двузначные часы утра / вечера;H
= часы;HH
= двузначные часы
m
= минуты;mm
= 2-значные минуты;aaa
= AM / PM
s
= секунды;ss
= 2-значные секунды
S
= миллисекунды
var monthNames = [
"January", "February", "March", "April", "May", "June", "July",
"August", "September", "October", "November", "December"
];
var dayOfWeekNames = [
"Sunday", "Monday", "Tuesday",
"Wednesday", "Thursday", "Friday", "Saturday"
];
function formatDate(date, patternStr){
if (!patternStr) {
patternStr = 'M/d/yyyy';
}
var day = date.getDate(),
month = date.getMonth(),
year = date.getFullYear(),
hour = date.getHours(),
minute = date.getMinutes(),
second = date.getSeconds(),
miliseconds = date.getMilliseconds(),
h = hour % 12,
hh = twoDigitPad(h),
HH = twoDigitPad(hour),
mm = twoDigitPad(minute),
ss = twoDigitPad(second),
aaa = hour < 12 ? 'AM' : 'PM',
EEEE = dayOfWeekNames[date.getDay()],
EEE = EEEE.substr(0, 3),
dd = twoDigitPad(day),
M = month + 1,
MM = twoDigitPad(M),
MMMM = monthNames[month],
MMM = MMMM.substr(0, 3),
yyyy = year + "",
yy = yyyy.substr(2, 2)
;
// checks to see if month name will be used
if (patternStr.indexOf('MMM') > -1) {
patternStr = patternStr
.replace('MMMM', MMMM)
.replace('MMM', MMM);
}
else {
patternStr = patternStr
.replace('MM', MM)
.replace('M', M);
}
return patternStr
.replace('hh', hh).replace('h', h)
.replace('HH', HH).replace('H', hour)
.replace('mm', mm).replace('m', minute)
.replace('ss', ss).replace('s', second)
.replace('S', miliseconds)
.replace('dd', dd).replace('d', day)
.replace('EEEE', EEEE).replace('EEE', EEE)
.replace('yyyy', yyyy)
.replace('yy', yy)
.replace('aaa', aaa)
;
}
function twoDigitPad(num) {
return num < 10 ? "0" + num : num;
}
console.log(formatDate(new Date()));
console.log(formatDate(new Date(), 'dd-MMM-yyyy')); //OP's request
console.log(formatDate(new Date(), 'EEEE, MMMM d, yyyy HH:mm:ss.S aaa'));
console.log(formatDate(new Date(), 'EEE, MMM d, yyyy HH:mm'));
console.log(formatDate(new Date(), 'yyyy-MM-dd HH:mm:ss.S'));
console.log(formatDate(new Date(), 'M/dd/yyyy h:mmaaa'));
Спасибо, @ Джерри, за то, что вы подняли Luxon.