[javascript] JavaScript Date 객체에 30 분을 추가하는 방법은 무엇입니까?

다른 Date 객체보다 30 분 늦은 Date 객체를 얻고 싶습니다. JavaScript로 어떻게합니까?



답변

라이브러리 사용

많은 날짜 작업을 수행하는 경우 Datejs 또는 Moment.js 와 같은 JavaScript 날짜 라이브러리를 살펴볼 수 있습니다 . 예를 들어 Moment.js의 경우 다음과 같습니다.

var newDateObj = moment(oldDateObj).add(30, 'm').toDate();

바닐라 자바 ​​스크립트

이것은 혼돈의 대답 과 같지만 한 줄에 있습니다.

var newDateObj = new Date(oldDateObj.getTime() + diff*60000);

시간과 diff원하는 시간의 차이는 어디에 있습니까 oldDateObj? 부정적 일 수도 있습니다.

또는 여러 곳에서이 작업을 수행해야하는 경우 재사용 가능한 기능으로 :

function addMinutes(date, minutes) {
    return new Date(date.getTime() + minutes*60000);
}

그리고 이것이 분명하지 않은 경우에, 우리가 몇 분을 곱한 이유는 60000분을 밀리 초로 변환하는 것입니다.

바닐라 자바 ​​스크립트에주의하십시오. 데이트는 어렵다!

내일 날짜를 얻기 위해 날짜에 24 시간을 추가 할 수 있다고 생각할 수 있습니다. 잘못된!

addMinutes(myDate, 60*24); //DO NOT DO THIS

사용자가 일광 절약 시간을 준수하면 하루가 반드시 24 시간 인 것은 아닙니다. 일년에 하루 23 시간, 하루에 25 시간입니다. 예를 들어 2014 년 11 월 2 일 자정 이후 24 시간 동안 대부분의 미국과 캐나다에서 여전히 11 월 2 일입니다.

const NOV = 10; //because JS months are off by one...
addMinutes(new Date(2014, NOV, 2), 60*24); //In USA, prints 11pm on Nov 2, not 12am Nov 3!

이런 이유로 많은 작업을 수행해야하는 경우 위에서 언급 한 라이브러리 중 하나를 사용하는 것이 더 안전한 방법 입니다.

아래는 내가 작성한이 기능의보다 일반적인 버전입니다. 여전히 라이브러리를 사용하는 것이 좋지만 프로젝트에 과도하거나 불가능할 수 있습니다. 구문은 MySQL DATE_ADD 함수를 따라 모델링 됩니다.

/**
 * Adds time to a date. Modelled after MySQL DATE_ADD function.
 * Example: dateAdd(new Date(), 'minute', 30)  //returns 30 minutes from now.
 * https://stackoverflow.com/a/1214753/18511
 *
 * @param date  Date to start with
 * @param interval  One of: year, quarter, month, week, day, hour, minute, second
 * @param units  Number of units of the given interval to add.
 */
function dateAdd(date, interval, units) {
  if(!(date instanceof Date))
    return undefined;
  var ret = new Date(date); //don't change original date
  var checkRollover = function() { if(ret.getDate() != date.getDate()) ret.setDate(0);};
  switch(String(interval).toLowerCase()) {
    case 'year'   :  ret.setFullYear(ret.getFullYear() + units); checkRollover();  break;
    case 'quarter':  ret.setMonth(ret.getMonth() + 3*units); checkRollover();  break;
    case 'month'  :  ret.setMonth(ret.getMonth() + units); checkRollover();  break;
    case 'week'   :  ret.setDate(ret.getDate() + 7*units);  break;
    case 'day'    :  ret.setDate(ret.getDate() + units);  break;
    case 'hour'   :  ret.setTime(ret.getTime() + units*3600000);  break;
    case 'minute' :  ret.setTime(ret.getTime() + units*60000);  break;
    case 'second' :  ret.setTime(ret.getTime() + units*1000);  break;
    default       :  ret = undefined;  break;
  }
  return ret;
}

jsFiddle 데모 작업 .


답변

var d1 = new Date ();
var d2 = new Date ( d1 );
d2.setMinutes ( d1.getMinutes() + 30 );
alert ( d2 );


답변

var oldDateObj = new Date();
var newDateObj = new Date();
newDateObj.setTime(oldDateObj.getTime() + (30 * 60 * 1000));
console.log(newDateObj);


답변

var now = new Date();
now.setMinutes(now.getMinutes() + 30); // timestamp
now = new Date(now); // Date object
console.log(now);


답변

아마도 이런 식으로 뭔가?

var d = new Date();
var v = new Date();
v.setMinutes(d.getMinutes()+30);

console.log(v)


답변

JS에서 날짜와 함께 작동하도록 addSeconds, addMinutes, addHours, addDays, addWeeks, addMonths, addYears와 같은 7 개의 함수를 항상 만듭니다.

예를 볼 수 있습니다 : http://jsfiddle.net/tiagoajacobi/YHA8x/

사용하는 방법:

var now = new Date();
console.log(now.addMinutes(30));
console.log(now.addWeeks(3));

이것은 기능입니다 :

        Date.prototype.addSeconds = function(seconds) {
            this.setSeconds(this.getSeconds() + seconds);
            return this;
        };

        Date.prototype.addMinutes = function(minutes) {
            this.setMinutes(this.getMinutes() + minutes);
            return this;
        };

        Date.prototype.addHours = function(hours) {
            this.setHours(this.getHours() + hours);
            return this;
        };

        Date.prototype.addDays = function(days) {
            this.setDate(this.getDate() + days);
            return this;
        };

        Date.prototype.addWeeks = function(weeks) {
            this.addDays(weeks*7);
            return this;
        };

        Date.prototype.addMonths = function (months) {
            var dt = this.getDate();

            this.setMonth(this.getMonth() + months);
            var currDt = this.getDate();

            if (dt !== currDt) {
                this.addDays(-currDt);
            }

            return this;
        };

        Date.prototype.addYears = function(years) {
            var dt = this.getDate();

            this.setFullYear(this.getFullYear() + years);

            var currDt = this.getDate();

            if (dt !== currDt) {
                this.addDays(-currDt);
            }

            return this;
        };


답변

해결하는 가장 쉬운 방법은 자바 스크립트 날짜가 숫자 일뿐임을 인식하는 것입니다. 0또는 시작합니다 'Wed Dec 31 1969 18:00:00 GMT-0600 (CST). 모두 1는 밀리 초를 나타냅니다. 값을 가져와 해당 값을 사용하여 새 날짜를 인스턴스화하여 밀리 초를 더하거나 뺄 수 있습니다. 그 마음으로 쉽게 관리 할 수 ​​있습니다.

const minutesToAdjust = 10;
const millisecondsPerMinute = 60000;
const originalDate = new Date('11/20/2017 10:00 AM');
const modifiedDate1 = new Date(originalDate.valueOf() - (minutesToAdjust * millisecondsPerMinute));
const modifiedDate2 = new Date(originalDate.valueOf() + (minutesToAdjust * millisecondsPerMinute));

console.log(originalDate); // Mon Nov 20 2017 10:00:00 GMT-0600 (CST)
console.log(modifiedDate1); // Mon Nov 20 2017 09:50:00 GMT-0600 (CST)
console.log(modifiedDate2); // Mon Nov 20 2017 10:10:00 GMT-0600 (CST)