Risposte:
Dovresti effettuare il checkout dell'oggetto Date .
In particolare, puoi guardare il metodo getHours () per l'oggetto Date.
getHours () restituisce l'ora da 0 a 23, quindi assicurati di gestirla di conseguenza. Penso che 0-23 sia un po 'più intuitivo poiché il tempo militare va da 0 a 23, ma dipende da te.
Con questo in mente, il codice sarebbe qualcosa sulla falsariga di:
var date = new Date();
var current_hour = date.getHours();
Questa funzione restituisce la data e l'ora nel formato seguente: YYYY:MM:DD:HH:MM:SS
. Funziona anche in Node.js.
function getDateTime() {
var date = new Date();
var hour = date.getHours();
hour = (hour < 10 ? "0" : "") + hour;
var min = date.getMinutes();
min = (min < 10 ? "0" : "") + min;
var sec = date.getSeconds();
sec = (sec < 10 ? "0" : "") + sec;
var year = date.getFullYear();
var month = date.getMonth() + 1;
month = (month < 10 ? "0" : "") + month;
var day = date.getDate();
day = (day < 10 ? "0" : "") + day;
return year + ":" + month + ":" + day + ":" + hour + ":" + min + ":" + sec;
}
(new Date()).toJSON().slice(0, 19).replace(/[-T]/g, ':')
2020:06:10:10:12:35
mentre, il tuo è tornato: 2020:06:10:00:12:35
Sembra che non abbia considerato gli aggiustamenti del fuso orario.
Dai un'occhiata alla moment.js
libreria. Funziona con i browser così come con Node.JS. Ti permette di scrivere
moment().hour();
o
moment().hours();
senza previa scrittura di alcuna funzione.
C'è un metodo nativo per lavorare con la data
const date = new Date();
let hours = date.getHours();
Se vuoi solo la stringa dell'ora puoi usare questa espressione (con una semplice RegEx):
new Date().toISOString().match(/(\d{2}:){2}\d{2}/)[0]
// "23:00:59"
var date = new Date();
var year = date.getFullYear();
var month = date.getMonth() + 1;
month = (month < 10 ? "0" : "") + month;
var hour = date.getHours();
hour = (hour < 10 ? "0" : "") + hour;
var day = date.getDate();
day = (hour > 12 ? "" : "") + day - 1;
day = (day < 10 ? "0" : "") + day;
x = ":"
console.log( month + x + day + x + year )
Visualizzerà la data nel mese, il giorno e poi l'anno
Per la mia istanza l'ho usato come globale e poi l'ho chiamato per un controllo orario di quando l'orario di apertura.
Di seguito è tratto dal mio index.js
global.globalDay = new Date().getDay();
global.globalHours = new Date().getHours();
Per chiamare il valore del globale da un altro file
/*
Days of the Week.
Sunday = 0, Monday = 1, Tuesday = 2, Wensday = 3, Thursday = 4, Friday = 5, Saturday = 6
Hours of the Day.
0 = Midnight, 1 = 1am, 12 = Noon, 18 = 6pm, 23 = 11pm
*/
if (global.globalDay === 6 || global.globalDay === 0) {
console.log('Its the weekend.');
} else if (global.globalDay > 0 && global.globalDay < 6 && global.globalHours > 8 && global.globalHours < 18) {
console.log('During Business Hours!');
} else {
console.log("Outside of Business hours!");
}
Per avviare il tuo nodo nel fuso orario PST, usa il seguente comando in ubuntu.
TZ=\"/usr/share/zoneinfo/GMT+0\" && export TZ && npm start &
Quindi è possibile fare riferimento alla libreria delle date per ottenere le funzioni di data e ora di calcolo personalizzate nel nodo.
Per usarlo lato client , fai riferimento a questo link , scarica index.js e assertHelper.js e includilo nel tuo HTML.
<script src="assertHelper.js"></script>
<script type="text/javascript" src="index.js"></script>
$( document ).ready(function() {
DateLibrary.getDayOfWeek(new Date("2015-06-15"),{operationType:"Day_of_Week"}); // Output : Monday
}
È possibile utilizzare diverse funzioni come indicato negli esempi per ottenere date personalizzate.
Se il primo giorno della settimana è la domenica, quale giorno sarà il 15 giugno 2015.
DateLibrary.getDayOfWeek(new Date("2015-06-15"),
{operationType:"Day_Number_of_Week",
startDayOfWeek:"Sunday"}) // Output : 1
Se il primo giorno della settimana è martedì, il numero della settimana nell'anno sarà seguito nel 15 giugno 2015 come una delle date.
DateLibrary.getWeekNumber(new Date("2015-06-15"),
{operationType:"Week_of_Year",
startDayOfWeek:"Tuesday"}) // Output : 24
Fai riferimento ad altre funzioni per soddisfare i tuoi requisiti di data personalizzati.