Sprawdzanie, odbył się czy miesiąc od daty w postaci ciągu znaków(JS)

0

Pytanie

W mojej aplikacji JavaScript mam datę w postaci ciągu znaków, np.: 19/10/2021 (dd/mm/rrrr). Chcę sprawdzić, odbył się czy miesiąc z określonej daty, i zwrócić wartość true, jeśli tak. Staram się zrobić coś takiego jak w poniższym kodzie, ale to nie działa.

Mam jakieś dziwne wartości, gdy próbuję go debugować za pomocą konsoli.dzienniki i tym podobne, jestem nowy w js, więc nie wiem, gdzie robię coś źle.

var q = new Date();
var d = q.getDate();
var m = q.getMonth() + 1; //+1 because january is 0 and etc
var y = q.getFullYear();

var today = new Date(d, m, y);

mydate = userDate; // this is the string the app is receiving

if (today - mydate > 30) {
    return true;
} else {
    return false;
}

Z góry dziękuję.

date javascript
2021-11-23 20:24:55
5
0

Spróbuj to:

    var q = new Date();
    var d = q.getDate();
    var m = q.getMonth(); 
    var y = q.getFullYear();
    var today = new Date(y,m,d);
    var mydate = new Date("2021-11-22"); 
    if(((today - mydate)/ (1000 * 60 * 60 * 24)) > 30)
    {
        return true;
    }
    else
    {
      return false;
    }
2021-11-23 20:53:55
0

Po pierwsze, gdy ustawić q Dla new Date() to dzisiaj. Nie trzeba wyjmować z niego dzień, miesiąc i rok, a następnie zainstalować go ponownie. Więc na dziś możesz po prostu zrobić var today = new Date().

Po drugie, należy przejść do daty() y,m,d i nie d,m,y.

Po trzecie, jeśli вычтете jedną datę od drugiej, rozliczenie będzie się odbywać w milisekundach, a nie w dniach.

To powinno zadziałać:

var userDate = '19/10/2021';
var myDate = new Date(userDate.split('/').reverse());
var today = new Date();

var thirtyDays = 1000*60*60*24*30;

return today - myDate > thirtyDays;
2021-11-23 22:09:04

new Date(userDate.split('/').reverse()) prawie na pewno zwróci błędną datę.
RobG

@RobG jeśli userDate-jest to ciąg znaków w formacie dd/mm/rrrr, to userDate.split('/').reverse() zwróci tablicę, podobny [yyyy,mm,dd]. i to jest to, co konstruktora Date() pobiera jako parametry.
Mordy Stern

Mijamy jedną wartość, tablica. Cm. ECMA-262 i mój komentarz do tej odpowiedzi.
RobG
0

Ponieważ określenie "wiek w miesiącach"... elastyczne, najprostszy sposób-użyć niewielką arytmetyki, jak zorientowali się jej w głowie, i nie zawierać Date klasa.

Dla [a] ludzkiej interpretacji "wiek w miesiącach" zasada jest taka

  • Oblicz różnicę między dwoma datami w miesiącach, jak gdyby dzień miesiąca był 1-szym dniem miesiąca, dla obu dat

  • Odejmij 1, aby wykluczyć ostatni miesiąc

  • Następnie, jeśli dzień miesiąca ostatniego dnia okresu przypada na dzień miesiąca pierwszego dnia okresu lub po nim, [potencjalnie częściowy] ostatni miesiąc zakończony: dodaj 1, aby przywrócić licznik

Jedna łyżka dziegciu w beczce miodu jest to, że w miesiącach zawierają różną liczbę dni, w odniesieniu do przypadków, gdy 2 miesiące różnią się pod względem liczby dni.

Jednak, jeśli końcowy miesiąc krótszy początkowego, możesz znaleźć się w sytuacji, gdy warunek brzegowy nigdy nie może być wykonana (np. data rozpoczęcia-28 lutego, a data zakończenia-31 marca. Aby to naprawić, trzeba patrzeć na "koniec miesiąca" jak na okno w zakresie od ostatniego dnia początkowego miesiąca do ostatniego dnia ostatniego miesiąca włącznie.

To prowadzi do następnego kodu. Używam strukturę podobną do następującej, do reprezentowania chcesz:

{
  year:  2021 , // 4-digit year
  month:   11 , // month of year (1-12 mapping to January-December)
  day:     23   // day of month (1-[28-31] depending on year/month
}

Zapewnienie, aby dane w tej strukturze stanowiły ważną datę, pozostawione jako ćwiczenie dla czytelnika.

Kod nie jest taki trudny:

/**
 * 
 * @param {object} bgn       - start date of period
 * @param {number} bgn.year  - 4-digit year
 * @param {number} bgn.month - month of year [1-12]
 * @param {number} bgn.day   - day of month [1-31]
 * 
 * @param {object} end       - end date of period
 * @param {number} end.year  - 4-digit year
 * @param {number} end.month - month of year [1-12]
 * @param {number} end.day   - day of month [1-31]
 * 
*/
function diffInMonths( bgn , end ) {
  const between = ( x , min , max ) => x >= min && x <= max;

  // We'll need to add back the final month based on the following:
  // - end.day >=  bgn.day -- we've passed the month boundary, or
  // - end.day is within the end-of-month window
  //   (when the end month is shorter than the start month)
  const needAdjustment = end.day >= bgn.day
    || between( end.day, daysInMonth(bgn), daysInMonth(end) );
  const finalMonthAdjustment = needsAdjustment ? 1 : 0;

  const deltaM = 12 * ( end.year - bgn.year )
    + ( end.month - bgn.month )
    - 1                    // remove the final month from the equation
    + finalMonthAdjustment // add in the precomputed final month adjustment
    ;

  return deltaM;
}

/**
 * 
 * @param {object} dt       - date
 * @param {number} dt.year  - 4-digit year
 * @param {number} dt.month - month of year [1-12]
 * @param {number} dt.day   - day of month [1-31]
 *
 */
function daysInMonth(dt) {
  const leapYear = ( dt.year % 4 === 0 && dt.year % 100 !== 0 ) || dt.year % 400 === 0;
  const monthDays = leapYear ? daysPerMonthLeap : daysPerMonth;
  const days = monthDays[dt.month];
  return days;
}
//                                    jan feb mar apr may jun jul aug sep oct nov dec
//                         ---------- --- --- --- --- --- --- --- --- --- --- --- ---
const daysPerMonth     = [ undefined, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31, ];
const daysPerMonthLeap = [ undefined, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31, ];
2021-11-23 20:49:22
-1

Problem w tym, że вычитаете wiersz chcesz. Trzeba, aby moja data była tego samego typu, że i dziś.

mydate = new Date(userDate)

(Uwaga: To działa tylko w formacie "miesiąc/dzień/rok"

2021-11-24 04:30:59

"To działa tylko w formacie" miesiąc/dzień/rok "" nieprawda, wbudowane analizatory będą analizować (poprawnie lub w inny sposób) wiele formatów, często z różnymi wynikami. Porady ogólne: nie wbudowany parser", sortowanie d/m/y ręcznie, nie jest łatwe.
RobG
-1

Jeśli data jest w tym formacie (19/10/2021), można najpierw wyjąć je.

const thOneMonth = 1000*60*60*24*31 //31 days in milliseconds
let formated = '19/10/2021'.split('/')
let date = Date.parse(formated[2], formated[1]-1, formated[0])
let date2 = 1634591678400 //date + 2678400000 a month later. This is in UNIX format.
if(date + thOneMonth == date2 ){//31 days 
  //A month have passed  
  console.log(date + thOneMonth )
}

Jeśli chcesz wiedzieć, na przykład, 12 września, a następna data-12 października, trzeba wziąć pod uwagę, że wrzesień trwa 30 dni. Należy sprawdzić na podstawie 31/30/29/28-dniowych miesięcy.


const thMonth = 1000*60*60*24*30 //30 days in milliseconds
let formated = '19/10/2021'.split('/')
let date = new Date(formated[2], formated[1]-1, formated[0])// make months start from 0
let date2 = 1634591678400 //date + 2678400000 a month later
if([5,7,10,12].includes(date.getMonth()+1) && Date.parse(date) + thMonth == date2 ){ // 30 days months 1000*60*60*24*30 //it won't enter here
  //A month have passed  
  console.log(date + thMonth)
}

2021-11-23 20:59:52

Date.parse('19/10/2021'.split('/').reverse()) ma poważne wady, to skutecznie Date.parse('2021,10,19') że zwróci NaN przynajmniej w niektórych, jeśli nie we wszystkich implementacjach. Zobacz, dlaczego Date.parse daje błędne wyniki? i MDN: Data.sortowanie.
RobG

W innych językach

Ta strona jest w innych językach

Русский
..................................................................................................................
Italiano
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................