Respostas:
var start = new Date();
start.setHours(0,0,0,0);
var end = new Date();
end.setHours(23,59,59,999);
alert( start.toUTCString() + ':' + end.toUTCString() );
Se você precisar obter a hora UTC, pode usar UTC().
setUTCHours, em vez de setHourster tempo Universal
setHoursé perigoso, pois define o horário local, em vez do horário UTC.
Usando a biblioteca momentjs , isso pode ser alcançado com os métodos startOf()e endOf()no objeto date atual do momento, passando a string 'day'como argumentos:
GMT local:
var start = moment().startOf('day'); // set to 12:00 am today
var end = moment().endOf('day'); // set to 23:59 pm today
var start = moment.utc().startOf('day');
var end = moment.utc().endOf('day');
.toDate()no final para obter a data. var end = moment().endOf('day').toDate();
.unix()no final para obter o timestamp do unix em segundos :) assim:moment().startOf('day').unix()
moment(new Date()).endOf("day");, não funciona, mas moment().endOf("day");funciona.
moment-timezonee fazer isso: moment().tz('America/Chicago').startOf('day').toDate().
Usando a biblioteca luxon.js , o mesmo pode ser alcançado usando os métodos startOf e endOf passando o 'dia' como parâmetro
var DateTime = luxon.DateTime;
DateTime.local().startOf('day').toUTC().toISO(); //2017-11-16T18:30:00.000Z
DateTime.local().endOf('day').toUTC().toISO(); //2017-11-17T18:29:59.999Z
DateTime.fromISO(new Date().toISOString()).startOf('day').toUTC().toISO(); //2017-11-16T18:30:00.000Z
remova .toUTC () se você precisar apenas da hora local
e você pode perguntar por que não moment.js , a resposta está aqui para isso.
Em MomentJs, podemos declarar como:
const start = moment().format('YYYY-MM-DD 00:00:01');
const end = moment().format('YYYY-MM-DD 23:59:59');
Se você está interessado apenas em carimbos de data e hora no GMT, também pode fazer isso, que pode ser convenientemente adaptado para diferentes intervalos (hora:, 1000 * 60 * 6012 horas: 1000 * 60 * 60 * 12etc.)
const interval = 1000 * 60 * 60 * 24; // 24 hours in milliseconds
let startOfDay = Math.floor(Date.now() / interval) * interval;
let endOfDay = startOfDay + interval - 1; // 23:59:59:9999
FYI (versão mesclada do Tvanfosson)
retornará data real => data em que você está chamando a função
export const today = {
iso: {
start: () => new Date(new Date().setHours(0, 0, 0, 0)).toISOString(),
now: () => new Date().toISOString(),
end: () => new Date(new Date().setHours(23, 59, 59, 999)).toISOString()
},
local: {
start: () => new Date(new Date(new Date().setHours(0, 0, 0, 0)).toString().split('GMT')[0] + ' UTC').toISOString(),
now: () => new Date(new Date().toString().split('GMT')[0] + ' UTC').toISOString(),
end: () => new Date(new Date(new Date().setHours(23, 59, 59, 999)).toString().split('GMT')[0] + ' UTC').toISOString()
}
}
// Como usar
today.local.now(); //"2018-09-07T01:48:48.000Z" BAKU +04:00
today.iso.now(); // "2018-09-06T21:49:00.304Z" *
* é aplicável ao tipo de hora Instantânea no Java8, que converte sua hora local automaticamente, dependendo da sua região. (se você estiver planejando escrever um aplicativo global)
Eu prefiro usar a biblioteca date-fns para manipular a data. É realmente uma ótima ferramenta modular e consistente. Você pode começar e terminar o dia desta maneira:
var startOfDay = dateFns.startOfDay;
var endOfDay = dateFns.endOfDay;
console.log('start of day ==> ', startOfDay(new Date('2015-11-11')));
console.log('end of day ==> ', endOfDay(new Date('2015-11-11')));
<script src="https://cdnjs.cloudflare.com/ajax/libs/date-fns/1.29.0/date_fns.min.js"></script>
var end = new Date(start.getTime());para garantir que você tem mesmo ponto no tempo - no caso de você mudar datas entre início e final de inicialização - pode acontecer - apenas um bom hábito de entrar