Cuando alguien empieza a programar en JavaScript o TypeScript, una de las primeras dudas que aparece es esta: ¿null y undefined son lo mismo? A simple vista parecen equivalentes porque ambos representan la ausencia de un valor, pero en realidad expresan conceptos distintos, y usarlos de forma incorrecta puede provocar errores difíciles de rastrear.
En esta entrada veremos por qué existen dos valores “vacíos”, qué significa realmente cada uno, cuándo conviene usarlo y cómo los trata el lenguaje en diferentes situaciones. También revisaremos las implicaciones que tiene en TypeScript, donde la distinción entre ambos afecta a la definición de tipos, interfaces, clases y validaciones.
Tabla de contenidos
null y undefined?JavaScript es un lenguaje curioso en muchos sentidos. Se desarrolló en muy poco tiempo y algunas decisiones iniciales se quedaron para siempre dentro del estándar, incluso si hoy no parecen las más acertadas. Una de ellas es la convivencia de dos formas distintas de representar la ausencia de valor:
| Valor | Significado |
|---|---|
undefined | Algo no ha sido definido o no tiene asignación. |
null | Algo sí fue definido, pero se le asignó intencionalmente un valor vacío o no válido |
Es decir:
undefined aparece de forma automática cuando algo todavía no tiene valor.null es una decisión deliberada del desarrollador para indicar un valor vacío o no aplicable.undefined: lo que JavaScript asigna por defectoCuando declaramos una variable sin inicializarla, JavaScript le asigna automáticamente undefined:
let a; console.log(a); // undefined
Lo mismo ocurre cuando intentamos acceder a una propiedad que no existe:
const persona = { nombre: "Ana" };
console.log(persona.edad); // undefined En estos casos, el lenguaje nos está diciendo: “La variable o propiedad existe… pero aún no tiene un valor.”
Incluso las funciones, salvo que se indique explícitamente lo contrario, devuelven undefined:
function saludar() {
console.log("Hola");
}
const resultado = saludar();
console.log(resultado); // undefined null: el valor vacío intencionalA diferencia de undefined, null nunca aparece automáticamente. Solo lo vemos cuando se asigna a propósito:
let usuario = null; // no hay usuario activo por ahora
Esto significa que la variable existe, pero su contenido está vacío por decisión del desarrollador. Se usa para representar estados como:
Ejemplo:
let sesionActiva = null;
// ... más tarde en el programa
sesionActiva = { nombre: "Carlos", rol: "Admin" }; JavaScript tiene dos tipos de comparación:
== → comparación no estricta, permite conversiones de tipo=== → comparación estricta, no convierte tiposObservemos esto:
null == undefined // true null === undefined // false
Con == el lenguaje los considera equivalentes, pero realmente no lo son: sus tipos son distintos.
typeof undefined // "undefined" typeof null // "object" ← bug histórico del lenguaje
Este comportamiento de typeof null es un error reconocido desde los inicios de JavaScript, pero ya no puede corregirse sin romper millones de programas.
En el desarrollo diario se suele adoptar una convención clara:
✔ Usa undefined cuando algo podría no existir.
✔ Usa null cuando algo está definido pero está vacío de manera intencional.
Esto no solo mejora la consistencia del código, sino también la comunicación dentro del equipo.
TypeScript añade tipado estático y, con strictNullChecks activado, obliga a distinguir de forma explícita si un valor puede ser null o undefined. Esto previene numerosos errores antes de ejecutar el programa.
Por ejemplo:
interface Usuario {
nombre: string;
edad?: number; // puede ser undefined
} Aquí la propiedad edad puede o no existir. Es equivalente a edad: number | undefined.
En cambio:
interface Usuario {
nombre: string;
edad: number | null;
} La propiedad siempre existe, pero su valor puede ser null.
Elegir uno u otro cambia completamente la semántica y el comportamiento esperado.
Para finalizar, podemos enumerar algunas buenas prácticas a la hora de usar null o undefined en nuestro código:
null y undefined como sinónimos.En JavaScript:
undefined para ausencia de definición.null para ausencia intencional.En TypeScript:
strictNullChecks.?, ?? y ?..En APIs y bases de datos:
null indica un campo existente, pero sin valor.undefined no debe aparecer: en JSON se omite automáticamente.Aunque null y undefined puedan parecer equivalentes al principio, representan ideas diferentes y cumplen roles distintos dentro del lenguaje. Comprender esta diferencia es esencial para escribir código más claro, robusto y coherente, especialmente en proyectos grandes o en entornos donde se manejan estados complejos.
En resumen:
| Valor | Significado | Cuándo usarlo |
|---|---|---|
undefined | No tiene asignación | El valor podría no existir |
null | Valor vacío asignado a propósito | El campo existe, pero está “en pausa” |
Dominar esta distinción no solo mejora la calidad del código: también mejora la comunicación entre desarrolladores y reduce sorpresas en la ejecución.
Seguimos evolucionando el laboratorio de Analytics Lane y hoy lanzamos la versión 1.1, disponible en:…
“El interés compuesto es la octava maravilla del mundo. El que lo entiende lo gana…
Tienes los datos de ventas de tres productos en dos años distintos y quieres saber…
Imagina la situación. Tu equipo lleva tres años con un modelo en producción. No es…
Cuando un banco evalúa una solicitud de crédito necesita responder a una pregunta aparentemente simple:…
En el octavo aniversario de Analytics Lane seguimos ampliando nuestro laboratorio de aplicaciones interactivas y,…
This website uses cookies.