JavaScript/Oggetto Date
L'oggetto Date permette di gestire in modo semplice e veloce le date; nella pratica, un'istanza della classe Date identifica una data e le funzionalità della classe permettono di aggiungere o sottrarre anni, mesi o giorni o recuperarne il valore.
Costruttore
modificaIl metodo più semplice per creare una data è:
var data = new Date()
Nel caso non si passino valori al costruttore, verrà creata un oggetto Date contenente la data e l'ora corrente.
Altrimenti possiamo creare date precise con altri metodi:
- fornendo il numero di millisecondi passati dalla mezzanotte del primo gennaio 1970 (questo metodo è macchinoso ma è quello che più si avvicina al metodo con cui il computer ragiona con le date). Questo valore è chiamato timestamp.
- fornendo una stringa che indichi la data, ad esempio:
var data = new Date("10 July 2007");
var data2 = new Date("10-7-2007");
- Usando il metodo descritto nel secondo esempio, bisogna fare attenzione in quanto, essendo JavaScript eseguito con le impostazioni del client, per un utente USA invece che il 10 luglio 2007 la data sarà 7 ottobre 2007
- l'ultimo metodo è il migliore in quanto affidabilità e praticità messe assieme. La sintassi è:
var data = new Date(anno, mese, giorno, ora, minuti, secondi, millisecondi)
- Crea un oggetto data in base ai parametri passati; normalmente è possibile omettere l'ultimo parametro. Attenzione, gennaio è il mese 0 e non 1 e di conseguenza anche gli altri cambiano.
Metodi
modificaRecuperare i valori della data
modificagetDay()
: restituisce un numero da 0 a 6 corrispondente al giorno della settimana della data (Domenica è 0, Lunedì 1, ... Sabato 6)getDate()
: restituisce il giorno del mesegetMonth()
: restituisce il numero del mese (Gennaio è 0, Dicembre è 11)getFullYear()
: restituisce il numero dell'anno con quattro cifre.
Visti questi metodi, possiamo già creare una funzione che restituisca una stringa contenente la data formattata. La funzione prende come parametro un oggetto Date e formatta la data in esso contenuta:
function formattaData(data) {
var giornoS = data.getDay();
var giornoM = data.getDate();
var mese = data.getMonth();
var anno = data.getFullYear();
switch (giornoS) { //converte il numero in nome del giorno
case 0: //domenica
giornoS = "domenica";
break;
case 1:
giornoS = "lunedì";
break;
case 2:
giornoS = "martedì";
break;
case 3:
giornoS = "mercoledì";
break;
case 4:
giornoS = "giovedì";
break;
case 5:
giornoS = "venerdì";
break;
case 6: //sabato
giornoS = "sabato";
break;
}
switch (mese) { //converte il numero in nome del mese
case 0:
mese = "gennaio";
break;
case 1:
mese = "febbraio";
break;
case 2:
mese = "marzo";
break;
case 3:
mese = "aprile";
break;
case 4:
mese = "maggio";
break;
case 5:
mese = "giugno";
break;
case 6:
mese = "luglio";
break;
case 7:
mese = "agosto";
break;
case 8:
mese = "settembre";
break;
case 9:
mese = "ottobre";
break;
case 10:
mese = "novembre";
break;
case 11:
mese = "dicembre";
break;
}
//es. martedì 9 luglio 2007
return giornoS + " " + giornoM + " " + mese + " " + anno;
}
Possiamo usare la funzione in questi modi:
var d1 = new Date () //oggi
var d2 = new Date (2007, 6, 10);
document.write(formattaData(d1));
document.write(formattaData(d2));
La funzione potrebbe sembrare inutile data l'esistenza del metodo dell'oggetto Date toLocaleString()
che restituisce una stringa contenente la data formattata secondo le impostazioni locali dell'utente; tuttavia, per questo motivo, ad esempio, un utente inglese invece che martedì 10 luglio 2007
otterrebbe Tuesday, July 10, 2007 00:00:00
.
Impostare i valori della data
modificaL'oggetto Date permette inoltre di modificare la data memorizzata nell'oggetto Date tramite i metodi setDate()
, setMonth
e setFullYear
. Questi metodi sono molto utili, perché hanno la caratteristica di ragionare come è giusto fare per le date. Ad esempio:
var d = new Date(2007, 3, 4); //4 Aprile 2007
d.setDate(31);
In questo esempio impostiamo come giorno del mese di aprile il valore di 31, nonostante aprile conti solo 30 giorni. JavaScript lo sa e per questo porta la data al 1 di maggio. Questa funzionalità è spesso usata insieme ai metodi per ottenere le date:
d.setMonth(d.getMonth() - 6); //sei mesi prima
Lavorare con l'ora
modificaL'oggetto Date mette a disposizione funzioni analoghe anche per gestire le ore:
getHours()
,getMinutes()
,getSeconds()
egetMilliseconds
restituiscono rispettivamente l'ora, i minuti, i secondi e i millisecondi dell'oggetto Date. Ad esempio:
var d = new Date(2007, 3, 4, 23, 45, 6, 12); //4 aprile 2007, ore 23:45:6 (11 pm)
d.getSeconds(); //restituisce 6
Il metodo getMilliseconds
permette anche di cronometrare l'esecuzione di una porzione di codice o il caricamento della pagina HTML. Inseriamo in testa alle istruzioni da cronometrare il codice:
var dataPrima = new Date(); //adesso
//memorizza secondi e millisecondi
var sPrima = dataPrima.getSeconds();
var msPrima = dataPrima.getMilliseconds();
In questo modo salviamo i secondi e i millisecondi del momento in cui inizia il caricamento; poi inseriamo in fondo alla pagina:
var dataDopo = new Date(); //adesso
//memorizza secondi e millisecondi
var sDopo = dataDopo.getSeconds();
var msDopo = dataDopo.getMilliseconds();
document.write('Pagina caricata in ' + (sDopo - sPrima) + ' secondi e ' + Math.abs(msDopo - msPrima) + ' millisecondi');
Gestire i fusi orari
modificaTutte le funzioni che abbiamo visto lavorano sull'ora dell'utente o su quella impostata dalla pagina web. Non abbiamo però considerato che Internet è una rete che coinvolge centinaia di paesi e quasi tutti i fusi orari del nostro pianeta; per questo motivo JavaScript mette a disposizione delle funzioni basate sull'UTC (Universal Time Coordination), una convenzione precedentemente nota come GMT (Greenwich Mean Time) che rappresenta la data basandosi su quella del meridiano 0, passante per la famosa località di Greenwich. Ovviamente anche queste funzioni sono basate su una corretta configurazione del computer del client.
I metodi UTC ricalcano i metodi per il locale; per impostare l'ora UTC è necessario ad esempio usare il metodo setUTCHour
; esiste inoltre un metodo toUTCString
che restituisce l'ora formattata secondo le convenzioni UTC e un metodo getTimeZoneOffset
che restituisce in minuti la differenza di ora tra il fuso di Greenwich e quello dell'utente (può essere anche negativo).