Verifica se è passato un mese da una data in formato stringa(JS)

0

Domanda

Nella mia applicazione JavaScript sto ricevendo una data in una stringa di formato, come questo: 19/10/2021 (gg/mm/aaaa). Voglio controllare se è passato un mese dal detto la data e restituiscono true se è così. Sto cercando qualcosa di simile al seguente codice, ma non funziona.

Sto diventando un po ' strano valori quando cerco di debug con la console.registri e simili, sono un newbie in js, quindi non so dove sto facendo qualcosa di sbagliato.

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;
}

Grazie in anticipo.

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

Prova questo:

    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

Prima, quando si imposta q per new Date() è di oggi. Non c'è bisogno di ottenere da lui il giorno, il mese e l'anno e quindi impostare di nuovo. Così per oggi, si può solo fare var today = new Date().

Secound, si dovrebbe passare in Data() y,m,d e non d,m,y.

Terzo, se si sottrae da una data da un altro, il calcolo sarà milisecounds, non in giorni.

Questo dovrebbe funzionare:

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()) sarà quasi certamente tornare una Data non valida.
RobG

@RobG se userDate è una stringa nel formato gg/mm/aaaa, quindi userDate.split('/').reverse() ritorna un array come [yyyy,mm,dd]. e questo è ciò che la Data() costruttore è sempre come parametri.
Mordy Stern

Stai passando un singolo valore di un array. Vedere ECMA-262 e il mio commento su questa risposta.
RobG
0

Poiché la definizione di "età in mesi" è... flessibile, il modo più semplice è quello di utilizzare un po ' di aritmetica, come si dovrebbe calcolare in testa, e non comportano la Date classe.

Per [a] interpretazione umana di "età in mesi", la regola è

  • Calcolare la differenza tra due date in mesi, come se il giorno del mese è stato il 1 ° del mese per entrambe le date

  • Sottrarre 1 per escludere l'ultimo mese

  • Quindi, se il giorno del mese, dell' ultimo giorno del periodo è o dopo il giorno del mese, il primo giorno del periodo, il [potenzialmente parziale] l'ultimo mese è completo: aggiungere 1 per ripristinare il conteggio

L'unico neo è, da mesi, contengono un diverso numero di giorni, occupandosi di casi in cui i 2 mesi differiscono nel numero di giorni.

Se, tuttavia, il fine mese è inferiore a inizio mese, è possibile ottenere in una situazione in cui la condizione al contorno non possono mai essere soddisfatte (ad esempio, la data di inizio è il 28 febbraio e la data di scadenza è il 31 Marzo. Per risolvere questo problema, è necessario guardare alla "fine del mese" come una finestra che vanno dall'ultimo giorno del mese di inizio attraverso l'ultimo giorno del mese di fine inclusive.

Che porta a questo codice. Sto utilizzando una struttura come la seguente per rappresentare una data:

{
  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
}

Garantire che i dati in tale struttura rappresenta una data valida è lasciato come esercizio per il lettore.

Il codice non è così complicato:

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

Il problema è che si sono sottraendo una stringa data. Hai bisogno di mydate essere lo stesso tipo come oggi.

mydate = new Date(userDate)

(Nota: Questo funziona solo con il 'mese/giorno/anno formato

2021-11-24 04:30:59

"Questo funziona solo con il 'mese/giorno/anno formato" non è corretto, built–in parser analizza (a torto o a ragione) una moltitudine di formati, spesso con risultati diversi. Un consiglio generale è: "non utilizzare il built–in del parser", manualmente l'analisi di d/m/y non è difficile.
RobG
-1

Se la data è in questo formato (19/10/2021) è possibile estrarre prima di loro.

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 )
}

Se si desidera sapere se per esempio, il 12 settembre, e il prossimo appuntamento è per il 12 ottobre, È necessario considerare che settembre è di 30 giorni. Devi controllare basato su 31/30/29/28 giorni mesi.


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()) è gravemente viziata, è effettivamente Date.parse('2021,10,19') che restituisce NaN in almeno alcuni, se non tutti, implementazioni. Vedere Perché Data.analizzare dare risultati non corretti? e MDN: Data.analizzare.
RobG

In altre lingue

Questa pagina è in altre lingue

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