Javascript добавить ведущие нули на сегодняшний день - PullRequest
373 голосов
/ 31 августа 2010

Я создал этот скрипт для расчета даты за 10 дней вперед в формате дд / мм / гггг:

var MyDate = new Date();
var MyDateString = new Date();
MyDate.setDate(MyDate.getDate()+10);
MyDateString = MyDate.getDate() + '/' + (MyDate.getMonth()+1) + '/' + MyDate.getFullYear();

Мне нужно, чтобы дата добавлялась с начальными нулями в компоненте день и месяц, чтобы добавить эти правила в скрипт. Я не могу заставить его работать.

if (MyDate.getMonth < 10)getMonth = '0' + getMonth;

и

if (MyDate.getDate <10)get.Date = '0' + getDate;

Если бы кто-то мог показать мне, куда вставить их в сценарий, я был бы очень благодарен.

Ответы [ 20 ]

1210 голосов
/ 31 августа 2010

Попробуйте это: http://jsfiddle.net/xA5B7/

var MyDate = new Date();
var MyDateString;

MyDate.setDate(MyDate.getDate() + 20);

MyDateString = ('0' + MyDate.getDate()).slice(-2) + '/'
             + ('0' + (MyDate.getMonth()+1)).slice(-2) + '/'
             + MyDate.getFullYear();

EDIT:

Для объяснения .slice(-2) дает нам последний два символа строки.

Так что, несмотря ни на что, мы можем добавить "0" к дню или месяцу и просто спросить последние два, поскольку это всегда те два, которые мы хотим.

Так что если MyDate.getMonth() вернет 9, это будет:

("0" + "9") // Giving us "09"

поэтому добавив .slice(-2), мы получим два последних символа:

("0" + "9").slice(-2)
"09"

Но если MyDate.getMonth() вернет 10, это будет:

("0" + "10") // Giving us "010"

поэтому добавление .slice(-2) дает нам последние два символа или:

("0" + "10").slice(-2)
"10"
95 голосов
/ 23 сентября 2012

Вот пример из Объекта Date документы в Mozilla Developer Network с использованием пользовательской функции «pad», без необходимости расширения прототипа Javascript Number.Удобная функция, которую они приводят в качестве примера:

function pad(n){return n<10 ? '0'+n : n}

И ниже она используется в контексте.

/* 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
41 голосов
/ 12 марта 2015

Вы можете определить функцию "str_pad" (как в php):

function str_pad(n) {
    return String("00" + n).slice(-2);
}
20 голосов
/ 07 ноября 2017

Новый современный способ сделать это - использовать toLocaleDateString, поскольку он не только позволяет форматировать дату с правильной локализацией, вы даже можете передавать параметры форматирования для архивирования желаемого результата:

var date = new Date(2018, 2, 1);
var result = date.toLocaleDateString("en-GB", { // you can skip the first argument
  year: "numeric",
  month: "2-digit",
  day: "2-digit",
});
console.log(result);

Когда вы пропустите первый аргумент, он вместо этого будет определять язык браузера. Кроме того, вы также можете использовать 2-digit в опции года.

Если вам не нужно поддерживать старые браузеры, такие как IE10, это самый чистый способ сделать эту работу. IE10 и более низкие версии не будут понимать аргумент параметров.

17 голосов
/ 12 декабря 2017

Для вас, людей из будущего (ECMAScript 2017 и выше)

Решение

"use strict"

const today = new Date()

const year = today.getFullYear()

const month = `${today.getMonth() + 1}`.padStart(2, 0)

const day = `${today.getDate()}`.padStart(2, 0)

const stringDate = [day, month, year].join("/") // 13/12/2017

Объяснение

String.prototype.padStart(targetLength[, padString]) добавляет какстолько, сколько возможно padString в цели String.prototype, поэтому новая длина цели будет targetLength.

Пример

"use strict"

let month = "9"

month = month.padStart(2, 0) // "09"

let byte = "00000100"

byte = byte.padStart(8, 0) // "00000100"
11 голосов
/ 31 августа 2010
Number.prototype.padZero= function(len){
 var s= String(this), c= '0';
 len= len || 2;
 while(s.length < len) s= c + s;
 return s;
}

// используется:

(function(){
 var myDate= new Date(), myDateString;
 myDate.setDate(myDate.getDate()+10);

 myDateString= [myDate.getDate().padZero(),
 (myDate.getMonth()+1).padZero(),
 myDate.getFullYear()].join('/');

 alert(myDateString);
})()

/*  value: (String)
09/09/2010
*/
7 голосов
/ 15 июля 2012
var MyDate = new Date();
var MyDateString = '';
MyDate.setDate(MyDate.getDate());
var tempoMonth = (MyDate.getMonth()+1);
var tempoDate = (MyDate.getDate());
if (tempoMonth < 10) tempoMonth = '0' + tempoMonth;
if (tempoDate < 10) tempoDate = '0' + tempoDate;
MyDateString = tempoDate + '/' + tempoMonth + '/' + MyDate.getFullYear();
3 голосов
/ 14 марта 2014

Вы можете использовать троичный оператор для форматирования даты как оператор «if».

Например:

var MyDate = new Date();
MyDate.setDate(MyDate.getDate()+10);
var MyDateString = (MyDate.getDate() < 10 ? '0' + MyDate.getDate() : MyDate.getDate()) + '/' + ((d.getMonth()+1) < 10 ? '0' + (d.getMonth()+1) : (d.getMonth()+1)) + '/' + MyDate.getFullYear();

Так что

(MyDate.getDate() < 10 ? '0' + MyDate.getDate() : MyDate.getDate())

будет похожев оператор if, где, если getDate () возвращает значение меньше 10, затем возвращает «0» + Дата, или же возвращает дату, если больше 10 (так как нам не нужно добавлять начальный 0).То же самое для месяца.

Редактировать: Забыл, что getMonth начинается с 0, поэтому добавил +1, чтобы учесть это.Конечно, вы могли бы также просто сказать d.getMonth () <9:, но я подумал, что использование +1 поможет сделать его более понятным. </p>

3 голосов
/ 03 марта 2013
function formatDate(jsDate){
  // add leading zeroes to jsDate when days or months are < 10.. 
  // i.e.
  //     formatDate(new Date("1/3/2013")); 
  // returns
  //    "01/03/2103"
  ////////////////////
  return (jsDate.getDate()<10?("0"+jsDate.getDate()):jsDate.getDate()) + "/" + 
      ((jsDate.getMonth()+1)<10?("0"+(jsDate.getMonth()+1)):(jsDate.getMonth()+1)) + "/" + 
      jsDate.getFullYear();
}
3 голосов
/ 30 июня 2015

Сделайте вашу жизнь проще и используйте Moment.js пример кода:

var beginDateTime = moment()
  .format('DD-MM-YYYY HH:mm')
  .toString();

// Now will print 30-06-2015 17:55
console.log(beginDateTime);
...