[javascript] 자바 스크립트는 날짜에 선행 0을 추가합니다

dd / mm / yyyy 형식으로 미리 10 일 동안 날짜를 계산하기 위해이 스크립트를 작성했습니다.

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

이 규칙을 스크립트에 추가하여 날짜와 요일 구성 요소에 날짜가 선행 0으로 표시되도록해야합니다. 작동하지 않는 것 같습니다.

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

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

누군가 스크립트에 삽입 할 위치를 보여 줄 수 있다면 정말 감사 할 것입니다.



답변

이것을 시도하십시오 : 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();

편집하다:

설명 을 위해 문자열 .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"


답변

다음은 Javascript의 Number 프로토 타입을 확장하지 않고도 사용자 정의 “pad”기능을 사용하는 Mozilla Developer Network 의 Date 오브젝트 문서 의 예입니다 . 그들이 보여주는 편리한 기능은

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


답변

이를위한 새로운 현대적인 방법은을 사용 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 이하 버전은 옵션 인수를 이해하지 못합니다.

참고 : toLocaleTimeString날짜 시간을 현지화하거나 형식을 지정하려는 경우 에도 있습니다.


답변

“str_pad”함수를 정의 할 수 있습니다 (php에서와 같이).

function str_pad(n) {
    return String("00" + n).slice(-2);
}


답변

미래의 사람들을 위해 (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"


답변

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
*/


답변

나는 이것을하는 짧은 방법을 발견했다.

 MyDateString.replace(/(^|\D)(\d)(?!\d)/g, '$10$2');

모든 외로운 단일 숫자에 선행 0을 추가합니다.