Я намагаюся використовувати JS для перетворення date object
рядка у YYYYMMDD
формат. Є простіший спосіб , ніж конкатенації Date.getYear()
, Date.getMonth()
і Date.getDay()
?
Я намагаюся використовувати JS для перетворення date object
рядка у YYYYMMDD
формат. Є простіший спосіб , ніж конкатенації Date.getYear()
, Date.getMonth()
і Date.getDay()
?
Відповіді:
Змінений фрагмент коду, який я часто використовую:
Date.prototype.yyyymmdd = function() {
var mm = this.getMonth() + 1; // getMonth() is zero-based
var dd = this.getDate();
return [this.getFullYear(),
(mm>9 ? '' : '0') + mm,
(dd>9 ? '' : '0') + dd
].join('');
};
var date = new Date();
date.yyyymmdd();
[1]
на .length===2
, тому що індексатор рядка не підтримується повністю. Дивіться цю відповідь з причин, чому.
[this.getFullYear(), mm<10 ? '0'+ mm: mm, dd<10 ? '0'+ dd : dd].join('.')
var mm = (this.getMonth() + 101).toString().substring(1, 3)
Мені не сподобалося додавання до прототипу. Альтернативою може бути:
var rightNow = new Date();
var res = rightNow.toISOString().slice(0,10).replace(/-/g,"");
<!-- Next line is for code snippet output only -->
document.body.innerHTML += res;
rightNow
змінна навколо, ви можете обернути її new Date
і повернути все в один рядок:(new Date()).toISOString().slice(0,10).replace(/-/g,"")
YYYYMMDDHHmmSSsss
, щоб я зробив це: var ds = (new Date()).toISOString().replace(/[^0-9]/g, "");
. Досить простий, але повинен бути інкапсульованим.
rightNow.setMinutes(rightNow.getMinutes() - rightNow.getTimezoneOffset()); rightNow.toISOString().slice(0,10)
Ви можете використовувати toISOString
функцію:
var today = new Date();
today.toISOString().substring(0, 10);
Це дасть вам формат "yyyy-mm-dd".
var date = new Date();
var formattedDate = moment(date).format('YYYYMMDD');
var formattedDate = moment().format('YYYYMMDD');
Якщо вам не потрібно чисте рішення JS, ви можете використовувати інтерфейс jQuery для виконання такої роботи:
$.datepicker.formatDate('yymmdd', new Date());
Зазвичай я не люблю імпортувати занадто багато бібліотек. Але користувальницький інтерфейс jQuery настільки корисний, ви, ймовірно, будете використовувати його десь у вашому проекті.
Перейдіть на сторінку http://api.jqueryui.com/datepicker/ для отримання додаткових прикладів
Це єдиний рядок коду, який можна використовувати для створення YYYY-MM-DD
рядка сьогоднішньої дати.
var d = new Date().toISOString().slice(0,10);
toISOString()
дасть 2015-12-31T22: 00: 00 GMT +0 (дві години до цього).
new Date('Jun 5 2016').
toLocaleString('en-us', {year: 'numeric', month: '2-digit', day: '2-digit'}).
replace(/(\d+)\/(\d+)\/(\d+)/, '$3-$1-$2');
// => '2016-06-05'
new Date('Sun Mar 31 2019 00:00:00.000').toLocaleString('en-us', {year: 'numeric', month: '2-digit', day: '2-digit'}).replace(/(\d+)\/(\d+)\/(\d+)/, '$3-$1-$2');
На додаток до відповіді oo, я хотів би порекомендувати відокремлювати логічні операції від повернення і замість них поставити їх як тернарі.
Також використовуйте concat()
для забезпечення безпечного конкатенації змінних
Date.prototype.yyyymmdd = function() {
var yyyy = this.getFullYear();
var mm = this.getMonth() < 9 ? "0" + (this.getMonth() + 1) : (this.getMonth() + 1); // getMonth() is zero-based
var dd = this.getDate() < 10 ? "0" + this.getDate() : this.getDate();
return "".concat(yyyy).concat(mm).concat(dd);
};
Date.prototype.yyyymmddhhmm = function() {
var yyyymmdd = this.yyyymmdd();
var hh = this.getHours() < 10 ? "0" + this.getHours() : this.getHours();
var min = this.getMinutes() < 10 ? "0" + this.getMinutes() : this.getMinutes();
return "".concat(yyyymmdd).concat(hh).concat(min);
};
Date.prototype.yyyymmddhhmmss = function() {
var yyyymmddhhmm = this.yyyymmddhhmm();
var ss = this.getSeconds() < 10 ? "0" + this.getSeconds() : this.getSeconds();
return "".concat(yyyymmddhhmm).concat(ss);
};
var d = new Date();
document.getElementById("a").innerHTML = d.yyyymmdd();
document.getElementById("b").innerHTML = d.yyyymmddhhmm();
document.getElementById("c").innerHTML = d.yyyymmddhhmmss();
<div>
yyyymmdd: <span id="a"></span>
</div>
<div>
yyyymmddhhmm: <span id="b"></span>
</div>
<div>
yyyymmddhhmmss: <span id="c"></span>
</div>
("00" + (this.getDate())).slice(-2)
для отримання двоцифрових чисел. Немає оператора "якщо" чи "?:" І менше дзвінків до функції .getX (). Якщо не трохи швидше, то принаймні читабельніше.
Мені не подобається змінювати рідні об'єкти, і я думаю, що множення чіткіше, ніж обробка рядків прийнятим рішенням.
function yyyymmdd(dateIn) {
var yyyy = dateIn.getFullYear();
var mm = dateIn.getMonth() + 1; // getMonth() is zero-based
var dd = dateIn.getDate();
return String(10000 * yyyy + 100 * mm + dd); // Leading zeros for mm and dd
}
var today = new Date();
console.log(yyyymmdd(today));
.replace('-', '')
щоб відповісти на питання ОП), тоді як ви були вірними оригінальному питанню ОП, і це не вимагало б цього додаткового кроку. Відмінно!
Просте рішення JS (ES5) без можливих проблем зі стрибком дати, спричинене друком Date.toISOString () у UTC:
var now = new Date();
var todayUTC = new Date(Date.UTC(now.getFullYear(), now.getMonth(), now.getDate()));
return todayUTC.toISOString().slice(0, 10).replace(/-/g, '');
Це у відповідь на коментар @ weberste щодо відповіді @Pierre Guilbert.
toISOString
повернути кілька послідовних дефісів?
// UTC/GMT 0
document.write('UTC/GMT 0: ' + (new Date()).toISOString().slice(0, 19).replace(/[^0-9]/g, "")); // 20150812013509
// Client local time
document.write('<br/>Local time: ' + (new Date(Date.now()-(new Date()).getTimezoneOffset() * 60000)).toISOString().slice(0, 19).replace(/[^0-9]/g, "")); // 20150812113509
var someDate = new Date();
var dateFormated = someDate.toISOString().substr(0,10);
console.log(dateFormated);
new Date()
створює новий об’єкт дати, який є просто обгорткою навколо nr. мс з 1970/01/01 00: 00: 00,000 UTC. Потім toISOString
друкується в локальному часовому поясі.
Інший спосіб - це використання toLocaleDateString
з локальним словом, який має стандарт формату великих дат , наприклад Швеція, Литва, Угорщина, Південна Корея, ...:
date.toLocaleDateString('se')
Щоб видалити роздільники ( -
), це лише питання заміни нецифрових знаків:
console.log( new Date().toLocaleDateString('se').replace(/\D/g, '') );
Це не має потенційної помилки, яку ви можете отримати при форматах дат UTC: дата UTC може бути одним вихідним днем порівняно з датою в локальному часовому поясі.
Ви можете просто використовувати цей код одного рядка, щоб отримати дату в році
var date = new Date().getFullYear() + "-" + (parseInt(new Date().getMonth()) + 1) + "-" + new Date().getDate();
Трохи спрощена версія для найпопулярнішої відповіді в цій темі https://stackoverflow.com/a/3067896/5437379 :
function toYYYYMMDD(d) {
var yyyy = d.getFullYear().toString();
var mm = (d.getMonth() + 101).toString().slice(-2);
var dd = (d.getDate() + 100).toString().slice(-2);
return yyyy + mm + dd;
}
dateformat - це дуже вживаний пакет.
Як користуватись:
Завантажте та встановіть dateformat
з NPM. Вимагайте цього у своєму модулі:
const dateFormat = require('dateformat');
а потім просто відформатуйте свої речі:
const myYYYYmmddDate = dateformat(new Date(), 'yyyy-mm-dd');
Цей хлопець тут => http://blog.stevenlevithan.com/archives/date-time-format написав format()
функцію для JavascriptDate
об’єкта , тому його можна використовувати у знайомих буквальних форматах.
Якщо вам потрібно повноформатне форматування дати у Javascript вашого додатка, використовуйте його. Інакше, якщо те, що ви хочете зробити, це одноразовий, то, можливо, найпростіше поєднати getYear (), getMonth (), getDay ().
Працюючи з відповіді @ oo, це поверне вам рядок дати відповідно до рядка формату. Ви можете легко додати двозначний рігекс року за рік і мілісекунди і такий, якщо вони вам потрібні.
Date.prototype.getFromFormat = function(format) {
var yyyy = this.getFullYear().toString();
format = format.replace(/yyyy/g, yyyy)
var mm = (this.getMonth()+1).toString();
format = format.replace(/mm/g, (mm[1]?mm:"0"+mm[0]));
var dd = this.getDate().toString();
format = format.replace(/dd/g, (dd[1]?dd:"0"+dd[0]));
var hh = this.getHours().toString();
format = format.replace(/hh/g, (hh[1]?hh:"0"+hh[0]));
var ii = this.getMinutes().toString();
format = format.replace(/ii/g, (ii[1]?ii:"0"+ii[0]));
var ss = this.getSeconds().toString();
format = format.replace(/ss/g, (ss[1]?ss:"0"+ss[0]));
return format;
};
d = new Date();
var date = d.getFromFormat('yyyy-mm-dd hh:ii:ss');
alert(date);
Я не знаю, наскільки це ефективно, особливо мудро, оскільки він використовує багато регексу. Можливо, це могло б використовувати якусь роботу, я не опановую чисті js.
Схоже, що mootools надає Date().format()
: https://mootools.net/more/docs/1.6.0/Types/Date
Я не впевнений, чи варто його включати саме для цього конкретного завдання.
Я зазвичай використовую код нижче, коли мені потрібно це зробити.
var date = new Date($.now());
var dateString = (date.getFullYear() + '-'
+ ('0' + (date.getMonth() + 1)).slice(-2)
+ '-' + ('0' + (date.getDate())).slice(-2));
console.log(dateString); //Will print "2015-09-18" when this comment was written
Для пояснення .slice (-2) дає нам два останні символи рядка.
Тож незалежно від того, ми можемо додати "0" до дня чи місяця, і просто попросити останні два, оскільки це завжди два, яких ми хочемо.
Отже, якщо MyDate.getMonth () поверне 9, це буде:
("0" + "9") // Giving us "09"
тому додавання .slice (-2) дає нам два останні символи, які:
("0" + "9").slice(-2)
"09"
Але якщо date.getMonth () поверне 10, це буде:
("0" + "10") // Giving us "010"
тому додавання .slice (-2) дає нам два останні символи, або:
("0" + "10").slice(-2)
"10"
Якщо ви використовуєте AngularJs (до 1,5), ви можете використовувати фільтр дат :
var formattedDate = $filter('date')(myDate, 'yyyyMMdd')
Відповідь на іншу для простоти та читабельності.
Також не рекомендується редагувати наявні попередньо визначені члени класу новими методами:
function getDateInYYYYMMDD() {
let currentDate = new Date();
// year
let yyyy = '' + currentDate.getFullYear();
// month
let mm = ('0' + (currentDate.getMonth() + 1)); // prepend 0 // +1 is because Jan is 0
mm = mm.substr(mm.length - 2); // take last 2 chars
// day
let dd = ('0' + currentDate.getDate()); // prepend 0
dd = dd.substr(dd.length - 2); // take last 2 chars
return yyyy + "" + mm + "" + dd;
}
var currentDateYYYYMMDD = getDateInYYYYMMDD();
console.log('currentDateYYYYMMDD: ' + currentDateYYYYMMDD);
Як щодо Day.js ?
Це всього 2 КБ, і ви також можете dayjs().format('YYYY-MM-DD')
.
Якщо ви не проти включити додаткову (але маленьку) бібліотеку, Sugar.js надає безліч приємних функціональних можливостей для роботи з датами в JavaScript. Для форматування дати використовуйте функцію форматування :
new Date().format("{yyyy}{MM}{dd}")
yyyymmdd=x=>(f=x=>(x<10&&'0')+x,x.getFullYear()+f(x.getMonth()+1)+f(x.getDate()));
alert(yyyymmdd(new Date));
дата-короткий код на допомогу!
const dateShortcode = require('date-shortcode')
dateShortcode.parse('{YYYYMMDD}', new Date())
//=> '20180304'
Ось більш загальний підхід, що дозволяє використовувати компоненти дати та часу та сортувати однаково як число чи рядок.
Виходячи з порядку числення формату ISO Дата, перетворіть у локальний часовий пояс і видаліть нецифрові цифри. тобто:
// monkey patch version
Date.prototype.IsoNum = function (n) {
var tzoffset = this.getTimezoneOffset() * 60000; //offset in milliseconds
var localISOTime = (new Date(this - tzoffset)).toISOString().slice(0,-1);
return localISOTime.replace(/[-T:\.Z]/g, '').substring(0,n || 20); // YYYYMMDD
}
Використання
var d = new Date();
// Tue Jul 28 2015 15:02:53 GMT+0200 (W. Europe Daylight Time)
console.log(d.IsoNum(8)); // "20150728"
console.log(d.IsoNum(12)); // "201507281502"
console.log(d.IsoNum()); // "20150728150253272"
Рідний Javascript:
new Date().toLocaleString('zu-ZA').slice(0,10).replace(/-/g,'');