Comprobación de JavaScript para nulos frente a indefinidos y diferencia entre == y ===
¿Cómo verifico una variable si es
null
oundefined
y cuál es la diferencia entrenull
yundefined
?¿Cuál es la diferencia entre
==
y===
(es difícil buscar en Google "===")?
¿Cómo verifico una variable si es
null
oundefined
...?
es la variable null
:
if (a === null)
// or
if (a == null) // but see note below
...pero tenga en cuenta que esto último también será cierto si a
lo es undefined
.
Lo es undefined
:
if (typeof a === "undefined")
// or
if (a === undefined)
// or
if (a == undefined) // but see note below
...pero nuevamente, tenga en cuenta que el último es vago; también será cierto si a
lo es null
.
Ahora, a pesar de lo anterior, la forma habitual de comprobarlos es utilizar el hecho de que son falsos :
if (!a) {
// `a` is falsey, which includes `undefined` and `null`
// (and `""`, and `0`, and `NaN`, and [of course] `false`)
}
Esto está definido por ToBoolean en la especificación.
...y ¿cuál es la diferencia entre
null
yundefined
?
Ambos son valores que se suelen utilizar para indicar la ausencia de algo. undefined
es el más genérico, usado como valor predeterminado de las variables hasta que se les asigna algún otro valor, como el valor de los argumentos de la función que no se proporcionaron cuando se llamó a la función y como el valor que se obtiene cuando se le pregunta a un objeto. por una propiedad que no tiene. Pero también se puede utilizar explícitamente en todas esas situaciones. (Existe una diferencia entre un objeto que no tiene una propiedad y que tiene la propiedad con el valor undefined
; hay una diferencia entre llamar a una función con el valor undefined
de un argumento y dejar ese argumento fuera por completo).
null
es un poco más específico que undefined
: Es una referencia de objeto en blanco. JavaScript está escrito de forma flexible, por supuesto, pero no todas las cosas con las que interactúa JavaScript están escritas de forma flexible. Si una API como el DOM en los navegadores necesita una referencia de objeto que esté en blanco, usamos null
, no undefined
. Y de manera similar, la operación del DOM getElementById
devuelve una referencia de objeto, ya sea válida (si encontró el elemento DOM) o null
(si no lo encontró).
Curiosamente (o no), son sus propios tipos. Es decir, null
es el único valor en el tipo Nulo y undefined
es el único valor en el tipo Indefinido.
¿Cuál es la diferencia entre "==" y "==="?
La única diferencia entre ellos es que ==
utilizarán coerción de tipo para intentar que los valores coincidan, y ===
no lo harán. Entonces, por ejemplo "1" == 1
, es cierto, porque "1"
obliga a 1
. Pero "1" === 1
es falso porque los tipos no coinciden. ( "1" !== 1
es cierto.) El primer paso (real) ===
es "¿Son los mismos tipos de operandos?" y si la respuesta es "no", el resultado es false
. Si los tipos son los mismos, hace exactamente lo que ==
hace.
La coerción de tipos utiliza reglas bastante complejas y puede tener resultados sorprendentes (por ejemplo, "" == 0
es cierto).
Más en la especificación:
- Comparación de igualdad abstracta (
==
, también llamada igualdad "flexible") - Comparación estricta de igualdad (
===
)
La diferencia es sutil.
En JavaScript, una undefined
variable es una variable que nunca ha sido declarada o nunca se le ha asignado un valor. Digamos que declaras, var a;
por ejemplo, then a
will be undefined
, porque nunca se le asignó ningún valor.
Pero si luego lo asigna, a = null;
ahora a
será null
. En JavaScript null
es un objeto (pruebe typeof null
en una consola de JavaScript si no me cree), lo que significa que nulo es un valor (de hecho, incluso undefined
es un valor).
Ejemplo:
var a;
typeof a; # => "undefined"
a = null;
typeof null; # => "object"
Esto puede resultar útil en argumentos de funciones. Es posible que desee tener un valor predeterminado, pero considere que nulo es aceptable. En cuyo caso podrá hacer:
function doSomething(first, second, optional) {
if (typeof optional === "undefined") {
optional = "three";
}
// do something
}
Si omite el optional
parámetro, doSomething(1, 2) then
opcional será la "three"
cadena, pero si lo pasa, doSomething(1, 2, null)
entonces opcional será null
.
En cuanto a los comparadores igual ==
y estrictamente igual ===
, el primero es de tipo débil, mientras que estrictamente igual también verifica el tipo de valores. Eso significa que 0 == "0"
volverá a ser verdadero; while 0 === "0"
devolverá falso, porque un número no es una cadena.
Puede utilizar esos operadores para verificar entre undefined
un null
. Por ejemplo:
null === null # => true
undefined === undefined # => true
undefined === null # => false
undefined == null # => true
El último caso es interesante, porque te permite comprobar si una variable es indefinida o nula y nada más:
function test(val) {
return val == null;
}
test(null); # => true
test(undefined); # => true
La especificación es el lugar al que acudir para obtener respuestas completas a estas preguntas. Aquí hay un resumen:
- Para una variable
x
, puedes:
- compruebe si es
null
por comparación directa usando===
. Ejemplo:x === null
- compruebe si es
undefined
mediante cualquiera de dos métodos básicos: comparación directa conundefined
otypeof
. Por varias razones , prefierotypeof x === "undefined"
. - verifique si es una de
null
lasundefined
reglas==
de coerción de tipo ligeramente arcano que significa quex == null
hace exactamente lo que desea y usa y confía en ellas.
- compruebe si es
- La diferencia básica entre
==
y===
es que si los operandos son de diferentes tipos,===
siempre regresaráfalse
mientras==
convertirá uno o ambos operandos en el mismo tipo usando reglas que conducen a un comportamiento ligeramente poco intuitivo. Si los operandos son del mismo tipo (por ejemplo, ambos son cadenas, como en latypeof
comparación anterior),==
se===
comportarán exactamente igual.
Más lectura:
- La verdad, la igualdad y JavaScript de Angus Croll
- La coerción de JavaScript de Andrea Giammarchi desmitificada
- Preguntas frecuentes sobre comp.lang.javascript: conversión de tipos de JavaScript
¿Cómo verifico una variable si es nula o no está definida?
simplemente verifique si una variable tiene un valor válido como este:
if(variable)
devolverá verdadero si la variable no contiene:
- nulo
- indefinido
- 0
- FALSO
- "" (una cadena vacía)
- Yaya