Функция сбора DateTime DateAgo

Привет, мне нужна помощь с настройкой функции dateAgo. Что он делает, так это то, что он дает мне коллекцию дат с даты, прошедшей обратный отсчет, но моя проблема с моей функцией заключается в том, что она не показывает правильно 3-ю дату, она должна быть 17 вместо 16, может кто-нибудь увидеть, знают ли они, почему это такое случается

Date.prototype.datesAgo = function(num) {
    let date = this;
    let arr = [];

    for(let i = 0; i < num; i++) {
        arr.push(i.toString());
    }

    let days = arr.slice(0, num).join(' ');

    console.info(days)
    return days.split(' ').map(function(n) {

        date.setDate(date.getDate() - n);

        return (function(year, month, day) {
            return [year, month < 10 ? '0'+ month : month, day < 10 ? '0' + day : day].join('-');
        })(date.getFullYear(), date.getMonth(), date.getDate());
    }).join(',');
}


console.info(new Date('2018-05-19').datesAgo(3))
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
0
45
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

На каждой итерации вы изменяете исходный объект date:

date.setDate(date.getDate() - n);

Итак, на каждой последующей итерации вы вычитаете n из последняя итерацияdate, а не исходную дату. Вместо этого клонируйте исходный объект даты на каждой итерации:

Date.prototype.datesAgo = function(num) {
  const date = this;
  const dateStrs = Array.from({ length: num }, (_, i) => {
    const clonedDate = new Date(date.getTime());
    clonedDate.setDate(date.getDate() - i);
    return (function(year, month, day) {
      return [year, month < 10 ? '0' + month : month, day < 10 ? '0' + day : day].join('-');
    })(clonedDate.getFullYear(), clonedDate.getMonth(), clonedDate.getDate());
  });
  return dateStrs.join(',');
}
console.info(new Date('2018-05-19').datesAgo(3))

Спасибо за вашу помощь, очень ценим

ONYX 19.05.2018 05:53

Другие вопросы по теме