Agregar ceros a número con JavaScript

El día de hoy veremos una función muy simple con JavaScript para agregar ceros a la izquierda de un número hasta que el mismo tenga cierta longitud, es decir, rellenar con ceros a la izquierda hasta tener las cifras deseadas.

Esto funciona al generar series, entre otros casos. Veamos cómo hacerlo con JavaScript.

Explicación del algoritmo

Desconozco si ya existe una función nativa que haga esto. Yo prefiero hacerlo manualmente para conocer el algoritmo.

En este caso lo que se hace es calcular cuántos ceros hace falta agregar, y para ello restamos la cantidad de cifras deseada menos la longitud del número como cadena (es decir, la cantidad de cifras del número sin relleno).

Luego usamos la función repeat de las cadenas de JavaScript. Esa función repite una cadena las veces que se indique en el argumento. Lo repetimos según la cantidad de ceros faltantes y al final concatenamos con el número.

Rellenar número con ceros a la izquierda con JS

Veamos la función de JavaScript:

const rellenar = (relleno, numeroComoCadena, cantidadDeCifras) => {
    const cantidadDeCaracteresFaltantes = cantidadDeCifras - numeroComoCadena.length;
    return relleno.repeat(cantidadDeCaracteresFaltantes) + numeroComoCadena;
}

En este caso recibe el relleno que será una cadena de un carácter, el número como cadena y la cantidad de cifras del número. Un ejemplo de invocación junto con su salida es:

const numero = 21;
const cifrasDeseadas = 10;
const relleno = "0";
const rellenado = rellenar(relleno,numero.toString(), cifrasDeseadas);

La salida: 0000000021

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.

Dejar un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *