JavaScript, як отримати дату завтра у форматі dd-mm-yy


90

Я намагаюся отримати JavaScript для відображення дати завтра у форматі (дд-мм-рррр)

У мене є цей сценарій, який відображає сьогоднішню дату у форматі (дд-мм-рррр)

var currentDate = new Date()
var day = currentDate.getDate()
var month = currentDate.getMonth() + 1
var year = currentDate.getFullYear()
document.write("<b>" + day + "/" + month + "/" + year + "</b>")

Displays: 25/2/2012 (todays date of this post)

Але як мені змусити його відображати дату завтра в тому ж форматі, тобто 26/2/2012

Я спробував це:

var day = currentDate.getDate() + 1

Однак я міг би тримати +1і переходити більше 31, очевидно, що не більше 32 днів на місяць

Шукали години, але, здається, немає відповіді чи рішення навколо цього?

Відповіді:


176

Це має вирішити це дуже приємно для вас.

Якщо ви передасте конструктор дати час, він виконає решту роботи.

24 години 60 хвилин 60 секунд 1000 мілісекунд

var currentDate = new Date(new Date().getTime() + 24 * 60 * 60 * 1000);
var day = currentDate.getDate()
var month = currentDate.getMonth() + 1
var year = currentDate.getFullYear()
document.write("<b>" + day + "/" + month + "/" + year + "</b>")

Майте на увазі одне, що цей метод поверне дату рівно через 24 години, що може бути неточним навколо переходу на літній час.

Відповідь Філа працює в будь-який час:

var currentDate = new Date();
currentDate.setDate(currentDate.getDate() + 1);

Причиною редагування мого допису є те, що я сам створив помилку, яка виявилася під час переходу на літній час за моїм старим методом.


9
Дякую, трохи коротшеvar currentDate = new Date(+new Date() + 86400000);
Ікром

13
Зверніть увагу, що за допомогою цієї стратегії ви можете зіткнутися з проблемами, пов’язаними з переходом на літній час, через що один день у році має 23 години, а другий - 25. Відповідь Філа нижче дозволяє уникнути цієї проблеми.
gsf

3
new Date().getTime()можна спростити, якDate.now()
czerny

Вони обидва правильні, я не думаю, що IE8 має Date.now ().
Родерік Обріст

2
@ConorB, .getMonth () повертає 0 за січень, 1 за лютий ... і т.д. 11 за грудень. Додавання 1 перетворює його з індексу масиву на дату, яку можна прочитати.
Родерік Обріст

135

Клас JavaScript Dateвирішує це за вас

var d = new Date("2012-02-29")
console.log(d)
// Wed Feb 29 2012 11:00:00 GMT+1100 (EST)

d.setDate(d.getDate() + 1)
console.log(d)
// Thu Mar 01 2012 11:00:00 GMT+1100 (EST)

console.log(d.getDate())
// 1

Чи все одно це спрацює, якщо сьогодні був останній день місяця, наприклад 31-й? Якщо ви додасте +1, чи не отримаєте ви 32-е місце?
Тимо,

19
@Timo майже впевнений, що мій приклад демонструє саме це
Філ

1
О, так, ти маєш рацію. Я забув, що в лютому є лише 28 днів :-)
Тимо,

Сьогодні для мене це не вдалося, оскільки нова дата ('31.10.2016') повертає 'Нд жовтня 2016 23:00:00 GMT-0100 (AZOT)'. Я перебуваю на Азорських островах, і часовий пояс змінено з AZOST на
AZOT

@nunoarruda вибачте, не дуже впевнений, що ви там говорите чи яке відношення має до цієї відповіді
Філ

7

Я б використовував бібліотеку DateJS. Він може зробити саме це.

http://www.datejs.com/

Виконайте наступне:

var d = new Date.today().addDays(1).toString("dd-mm-yyyy");

Date.today() - дає вам сьогодні опівночі.


1
Мені більше подобається відповідь Філа ... Я використовую DateJS для всіх дат - але, схоже, це можна зробити, використовуючи лише JS!
MattW

4
Date.parse ('завтра'). ToString ('dd-MM-yyyy');
geoffrey.mcgill

5

Метод Date.prototype.setDate () приймає навіть аргументи поза стандартним діапазоном і відповідно змінює дату.

function getTomorrow() {
    const tomorrow = new Date();
    tomorrow.setDate(tomorrow.getDate() + 1); // even 32 is acceptable
    return `${tomorrow.getFullYear()}/${tomorrow.getMonth() + 1}/${tomorrow.getDate()}`;
}

4

Нижче використано комбінацію відповідей Родеріка та Філа з двома додатковими умовами, що враховують однозначні місяці / дні.

Багато API, з якими я працював, вимогливі до цього і вимагають, щоб дати мали вісім цифр (наприклад, „02022017“), замість 6 чи 7 цифр, які в деяких ситуаціях дасть вам клас дати.

function nextDayDate() {
      // get today's date then add one
      var nextDay = new Date();
      nextDay.setDate(nextDay.getDate() + 1);

      var month = nextDay.getMonth() + 1;
      var day = nextDay.getDate();
      var year = nextDay.getFullYear();

      if (month < 10) { month = "0" + month } 
      if (day < 10) { day = "0" + day }

      return month + day + year;
}

3

Варіанти використання:

Date.tomorrow() // 1 day next 
Date.daysNext(1) // alternative Date.tomorrow()
Date.daysNext(2) // 2 days next. 

ЯКЩО "завтра" залежить не від сьогодні, а від іншої Дати, яка відрізняється від Date.now(), Не використовуйте статичні методи, а скоріше ви повинні використовувати нестатичні:

тобто: пт. 05 грудня 2008 р

 var dec5_2008=new Date(Date.parse('2008/12/05'));
 dec5_2008.tomorrow(); // 2008/12/06
    dec5_2008.tomorrow().day // 6
    dec5_2008.tomorrow().month // 12
    dec5_2008.tomorrow().year //2008
 dec5_2008.daysNext(1); // the same as previous
 dec5_2008.daysNext(7) // next week :)

API:

Dateold=Date;function Date(e){var t=null;if(e){t=new Dateold(e)}else{t=new Dateold}t.day=t.getDate();t.month=t.getMonth()+1;t.year=t.getFullYear();return t}Date.prototype.daysNext=function(e){if(!e){e=0}return new Date(this.getTime()+24*60*60*1e3*e)};Date.prototype.daysAgo=function(e){if(!e){e=0}return Date.daysNext(-1*e)};Date.prototype.tomorrow=function(){return this.daysNext(1)};Date.prototype.yesterday=function(){return this.daysAgo(1)};Date.tomorrow=function(){return Date.daysNext(1)};Date.yesterday=function(){return Date.daysAgo(1)};Date.daysNext=function(e){if(!e){e=0}return new Date((new Date).getTime()+24*60*60*1e3*e)};Date.daysAgo=function(e){if(!e){e=0}return Date.daysNext(-1*e)}

3

Спосіб 1: Якщо у вас не виникає проблем із використанням іншої бібліотеки, це може допомогти вам, використовуючи moment.js

moment().add('days', 1).format('L');

Спосіб 2: Використовуючи Date.js,

<script type="text/javascript" src="date.js"></script>    
var tomorrow = new Date.today().addDays(1).toString("dd-mm-yyyy"); 

Цей метод використовує зовнішню бібліотеку, а не власну бібліотеку дат. Оскільки мій bootstrap-datetimepicker використовував moment.js та власну бібліотеку дат, я віддав перевагу методу 1. У цьому питанні згадуються ці та деякі інші методи.


2

Це дуже просто:

1: Створіть об’єкт дати із сьогоднішніми датою та часом. 2: Використовуйте методи об’єкта дати, щоб отримати день, місяць та повний рік та об’єднати їх за допомогою оператора +.

Відвідайте http://www.thesstech.com/javascript/date-time JavaScript, щоб отримати детальний підручник про дату та час.

Зразок коду:

  var my_date = new Date();  
  var tomorrow_date =       (my_date .getDate()+1)  + "-" + (my_date .getMonth()+1) + "-" + my_date .getFullYear();
  document.write(tomorrow_date);

Це не переноситься на дату на місяць, як вже спостерігалося в ОП.
Вольфганг Кюн

0
function getMonday(d)
{
   // var day = d.getDay();
   var day = @Config.WeekStartOn
   diff = d.getDate() - day + (day == 0 ? -6 : 0);
   return new Date(d.setDate(diff));
}

0

Те саме, що і вихідна відповідь, але в один рядок:

var tomorrow = new Date(Date.now() + 24 * 60 * 60 * 1000)

Цифри стоять 24 години 60 хвилин 60 секунд 1000 мілісекунд.


1
Ця відповідь не є правильною, оскільки перехід на літній час не враховується.
Розчарований

0

Ви можете спробувати це:

function Tomorrow(date=false) {
    var givendate = (date!=false) ? new Date(date) : new Date();
    givendate.setDate(givendate.getDate() + 1);
    var day = givendate.getUTCDate()
    var month = givendate.getUTCMonth()+1
    var year = givendate.getUTCFullYear()
    result ="<b>" + day + "/" + month + "/" + year + "</b>";
    return result;
} 
var day = Tomorrow('2020-06-30');
console.log('tomorrows1: '+Tomorrow('2020-06-30'));
console.log('tomorrows2: '+Tomorrow());


0
        Date.prototype.NextDay = function (e) {
        return new Date(this.getFullYear(), this.getMonth(), this.getDate() + ("string" == typeof e ? parseInt(e, 10) : e));
    }

    // tomorrow
    console.log(new Date().NextDay(1))

    // day after tomorrow
    console.log(new Date().NextDay(2))

0

Використовуючи лише JS (чистий js)

Сьогодні

new Date()
//Tue Oct 06 2020 12:34:29 GMT+0530 (India Standard Time)
new Date(new Date().setHours(0, 0, 0, 0))
//Tue Oct 06 2020 00:00:00 GMT+0530 (India Standard Time)
new Date(new Date().setHours(0, 0, 0,0)).toLocaleDateString('fr-CA')
//"2020-10-06"

Завтра

new Date(+new Date() + 86400000);
//Wed Oct 07 2020 12:44:02 GMT+0530 (India Standard Time)
new Date(+new Date().setHours(0, 0, 0, 0) + 86400000);
//Wed Oct 07 2020 00:00:00 GMT+0530 (India Standard Time)
new Date(+new Date().setHours(0, 0, 0,0)+ 86400000).toLocaleDateString('fr-CA')
//"2020-10-07"
//don't forget the '+' before new Date()

Післязавтра

Просто помножте на два напр .: - 2 * 86400000

Ви можете знайти всі локальні шорткоди з https://stackoverflow.com/a/3191729/7877099


-1
        //-----------Date Configuration march 18,2014----------------------

        //alert(DateFilter);

        var date = new Date();
        y = date.getFullYear(), m = date.getMonth();
        var EndDate = new Date();



        switch (DateFilter) {
            case 'today': var StartDate = EndDate;   //todays date                 
                break;
            case 'yesterday':
                var d = new Date();
                var previousDate = new Date(d.getTime() - 1000 * 60 * 60 * 24);
                var StartDate = new Date(previousDate.yyyymmdd()); //yesterday Date
                break;
            case 'tomorrow':
                var d = new Date();
                var NextDate = new Date(d.getTime() + 1000 * 60 * 60 * 24);
                var StartDate = new Date(NextDate.yyyymmdd()); //tomorrow Date
                break;
            case 'thisweek': var StartDate = getMonday(new Date()); //1st date of this week
                break;
            case 'thismonth': var StartDate = new Date(y, m, 1);  //1st date of this month
                break;
            case 'thisyear': var StartDate = new Date("01/01/" + date.getFullYear());  //1st date of this year
                break;
            case 'custom': //var StartDate = $("#txtFromDate").val();                   
                break;
            default:
                var d = new Date();
                var StartDate = new Date(d.getTime() - 30 * 24 * 60 * 60 * 1000); //one month ago date from now.
        }


        if (DateFilter != "custom") {
            var SDate = $.datepicker.formatDate('@Config.DateFormat', StartDate); $("#txtFromDate").val(SDate);
            var EDate = $.datepicker.formatDate('@Config.DateFormat', EndDate); $("#txtToDate").val(EDate);
        }
        //-----------Date Configuration march 18,2014----------------------

Будь ласка, додайте пояснення до своєї відповіді.
Амар

-1
var curDate = new Date().toLocaleString().split(',')[0];

Просто! у форматі dd.mm.yyyy.

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.