En este post voy a mostrarte una forma de formatear la fecha (o en términos específicos un objeto de tipo Date) en JavaScript.

No vamos a usar el método toLocaleString ni parecidos, crearemos un método propio ya que aunque hay métodos que pueden servir mejor, en ocasiones es necesario formatear la fecha en JavaScript de acuerdo a un formato manual.

Nota: si tú prefieres usar un método más elegante puedes usar DateTimeFormat de JS.

Métodos importantes de Date

Los objetos que son una instancia de Date tienen algunos métodos importantes. Entre ellos:

getFullYear: obtiene el año de 4 dígitos por ejemplo 2020

getMonth: obtiene el mes como un entero, comenzando en 0 para enero y terminando en 11 para diciembre

getDate: obtiene el día del mes, del 1 al 31 (en caso de que el mes tenga 31 días)

Así que con esto ya podemos crear nuestro propio formateador en forma de función. Por cierto, este método también funciona para la hora, pero eso será cosa de otro post.

Formatear fecha en JavaScript

Te voy a mostrar la función que uso para formatear la fecha en el formato YYYY-MM-DD por ejemplo 2020-03-21 (con cero a la izquierda incluido en caso de ser necesario). La función queda así:

const formatearFecha = fecha => {
    const mes = fecha.getMonth() + 1; // Ya que los meses los cuenta desde el 0
    const dia = fecha.getDate();
    return `${fecha.getFullYear()}-${(mes < 10 ? '0' : '').concat(mes)}-${(dia < 10 ? '0' : '').concat(dia)}`;
};

Lo que estoy haciendo es obtener el mes y el día por separado. Al mes le sumo 1. Después utilizo las plantillas de cadena o backticks (${}) para evaluar si el mes es menor a diez para agregarle un cero a la izquierda.

Hago lo mismo con el día (excepto lo de sumarle 1), y regreso el resultado de concatenar todo ello, usando también guiones para unirlos.

Probando código

Ahora veamos el código completo con una pequeña prueba.

// https://parzibyte.me/blog/
const formatearFecha = fecha => {
    const mes = fecha.getMonth() + 1; // Ya que los meses los cuenta desde el 0
    const dia = fecha.getDate();
    return `${fecha.getFullYear()}-${(mes < 10 ? '0' : '').concat(mes)}-${(dia < 10 ? '0' : '').concat(dia)}`;
};

// Probar con la fecha de hoy
const fechaDeHoy = new Date();
const fechaFormateada = formatearFecha(fechaDeHoy);
console.log(fechaFormateada);

Si quieres puedes ejecutarlo en línea.

Conclusión

Con este método puedes formatear la fecha a tu modo y a tu gusto. En lugar de guiones podrías usar barras / o también podrías colocar primero el día, luego el mes, el año, etcétera.

Si te gusta JavaScript te invito a aprender más en mi blog.

Si el post ha sido de tu agrado te invito a que me sigas para saber cuando haya escrito un nuevo post, haya actualizado algún sistema o publicado un nuevo software. Facebook | X | Instagram | Telegram | También estoy a tus órdenes para cualquier contratación en mi página de contacto