Baseline Widely available
El operador de comparacion (==
) comprueba si sus dos operandos son iguales y devuelve un resultado booleano. A diferencia del operador de igualdad estricta (===
), es que este convierte y compara operandos que son de diferentes tipos.
console.log(1 == 1);
// Expected output: true
console.log("hello" == "hello");
// Expected output: true
console.log("1" == 1);
// Expected output: true
console.log(0 == false);
// Expected output: true
Sintaxis Descripción
Los operadores de igualdad (==
y !=
) Utilizan el algoritmo de comparación de igualdad abstracta para comparar dos operandos. Esto se puede resumir a grandes rasgos como:
Si los operandos ambos son objetos, devuelve true
solo si ambos operandos hacen referencia al mismo objeto.
Si un operando es null
y el otro undefined
, devuelve verdadero(true
).
Si los operandos son de diferente tipos, intenta convertirlos al mismo tipo antes de comparar:
valueOf()
y toString()
del objeto.Si los operandos tienen el mismo tipo, se comparan de la siguiente manera:
String
: devuelve verdadero solo si ambos operandos tienen los mismos caracteres y en el mismo orden.Number
: devuelve verdadero solo si ambos operandos tienen el mismo valor. +0
y -0
se tratan como el mismo valor. Si alguno de los operandos es NaN
, devuelve falso.Boolean
: retorna verdadero solo si ambos operandos son verdaderos o falsos.La diferencia más notable entre este operador y el operador de igualdad estricta (===
) es que el operador de igualdad estricta no realiza la conversión de tipos.
1 == 1; // true
"Hola" == "Hola"; // true
Comparación con conversión de tipos
"1" == 1; // true
1 == "1"; // true
0 == false; // true
0 == null; // false
0 == undefined; // false
0 == !!null; // true, Operador Logico NOT
0 == !!undefined; // true, Operador Logico NOT
null == undefined; // true
const number1 = new Number(3);
const number2 = new Number(3);
number1 == 3; // true
number1 == number2; // false
Comparación de objetos
const object1 = { key: "value" };
const object2 = { key: "value" };
object1 == object2; // false
object2 == object2; // true
Comparar String y objetos String
Tenga en cuenta que las cadenas construidas con new String()
son objetos. Si compara uno de estos con un String literal, el objeto String se convertirá en un String
literal y se comparará el contenido. Sin embargo, si ambos operandos son objetos de tipo String, entonces se comparan como objetos y deben hacer referencia al mismo objeto para que la comparación sea exitosa:
const string1 = "Hola";
const string2 = String("Hola");
const string3 = new String("Hola");
const string4 = new String("Hola");
console.log(string1 == string2); // true
console.log(string1 == string3); // true
console.log(string2 == string3); // true
console.log(string3 == string4); // false
console.log(string4 == string4); // true
Comparación de fechas y cadenas
const d = new Date("December 17, 1995 03:24:00");
const s = d.toString(); // Por ejemplo: "Sun Dec 17 1995 03:24:00 GMT-0800 (Hora estándar del PacÃfico)"
console.log(d == s); //true
Especificaciones Compatibilidad con navegadores Ver también
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4