Cómo manipular un objeto Moment
Una vez que tengas un Moment
, es posible que desees manipularlo de alguna manera. Hay varios métodos para ayudar con esto.
Moment.js utiliza el patrón de interfaz fluido, también conocido como encadenamiento de métodos. Esto te permite hacer locuras como las siguientes.
Nota: Cabe señalar que los moments son mutables. Llamar a cualquiera de los métodos de manipulación cambiará el moment original.
Si deseas crear una copia y manipularla, debes usar moment#clone
antes de manipular el moment. Más información sobre la clonación.
El método add
Muta el moment original añadiendo tiempo.
Esta es una función bastante sólida para agregar tiempo a un momento existente. Para agregar tiempo, pasa la clave de a qué tiempo deseas agregar y la cantidad que deseas agregar.
También hay algunas claves de atajo si te gusta todo ese asunto de la brevedad.
Clave | Atajo |
---|---|
years | y |
quarters | Q |
months | M |
weeks | w |
days | d |
hours | h |
minutes | m |
seconds | s |
milliseconds | ms |
Si deseas agregar varias claves diferentes al mismo tiempo, puedes pasarlas como un objeto literal.
No hay límites superiores para las cantidades, por lo que puedes sobrecargar cualquiera de los parámetros.
Consideraciones especiales para meses y años
Si el día del mes en la fecha original es mayor que el número de días del mes final, el día del mes cambiará al último día del mes final.
También hay consideraciones especiales a tener en cuenta al agregar tiempo que cruza el horario de verano. Si agregas años, meses, semanas o días, la hora original siempre coincidirá con la hora agregada.
Agregar un mes agregará la cantidad especificada de meses a la fecha.
Si agregas horas, minutos, segundos o milisegundos, se supone que deseas precisión en la hora y el resultado será una hora diferente.
Alternativamente, puedes usar duraciones para agregar a moments.
Antes de la versión 2.8.0, también se admitía la sintaxis moment#add(String, Number)
. Ha quedado obsoleto en favor de moment#add(Number, String)
.
A partir de 2.12.0, cuando se pasan valores decimales para días y meses, se redondean al número entero más cercano. Las semanas, cuartos (trimestres) y años se convierten a días o meses y luego se redondean al número entero más cercano.
El método subtract
Muta el moment original restando tiempo.
Esto es exactamente lo mismo que moment#add
, solo que en lugar de sumar tiempo, lo resta.
Antes de la versión 2.8.0, también se admitía la sintaxis moment#subtract(String, Number)
. Ha quedado obsoleto en favor de moment#subtract(Number, String)
.
A partir de 2.12.0, cuando se pasan valores decimales para días y meses, se redondean al número entero más cercano. Las semanas, cuartos (trimestres) y años se convierten a días o meses y luego se redondean al número entero más cercano.
Ten en cuenta que para que las operaciones moment.add(-.5, 'days')
y moment.subtract(.5, 'days')
sean equivalentes, -.5
, -1.5
, -2.5
, etc. se redondean hacia abajo.
Al inicio de una unidad de tiempo
Muta el momento original configurándolo al inicio de una unidad de tiempo.
Estos atajos son esencialmente los mismos que los siguientes.
A partir de la versión 2.0.0, moment#startOf('day')
reemplazó a moment#sod
.
Nota: moment#startOf('week')
se agregó en la versión 2.0.0.
A partir de la versión 2.1.0, moment#startOf('week')
utiliza el día de inicio de la semana que reconoce la configuración regional.
Nota: moment#startOf('isoWeek')
se agregó en la versión 2.2.0.
Nota: moment#startOf('date')
se agregó como alias para el día en 2.13.0