Os operadores de comparação comparam os valores de dois operandos e avaliam se a
instrução que eles formam é true
ou false
. O exemplo a seguir usa o operador
strict equality (===
) para comparar dois operandos: a expressão
2 + 2
e o valor 4
. Como o resultado da expressão e o valor numérico 4
são iguais, esta expressão é avaliada como true
:
2 + 2 === 4
> true
Coerção de tipo e igualdade
Dois dos operadores de comparação mais usados são ==
para igualdade aproximada
e ===
para igualdade estrita. ==
realiza uma comparação aproximada entre dois
valores, forçando os operandos a corresponder aos tipos de dados, se possível. Por
exemplo, 2 == "2"
retorna true
, mesmo que a comparação seja feita
entre um valor numérico e um valor de string.
2 == 2
> true
2 == "2"
> true
O mesmo acontece com !=
, que retorna true
apenas se os operandos que estão sendo
comparados não forem vagamente iguais.
2 != 3
> true
2 != "2"
> false
Comparações estritas usando ===
ou !==
não realizam coerção de tipo. Para que uma
comparação estrita seja avaliada como true
, os valores comparados precisam ter o
mesmo tipo de dados. Por isso, 2 == "2"
retorna true
, mas 2 === "2"
retorna false
:
2 === 3
> false
2 === "2"
> false
Para remover qualquer ambiguidade que possa resultar da coerção automática, use ===
sempre que
possível.
Operador | Descrição | Uso | Resultado |
---|---|---|---|
=== | Estritamente igual | 2 === 2 | verdadeiro |
!== | Não é estritamente igual | 2 !== "2" | verdadeiro |
== | Igual (ou "vagamente igual") | 2 == "2" | verdadeiro |
!= | Diferente | 2 != "3" | verdadeiro |
> | Maior que | 3 > 2 | verdadeiro |
>= | Maior que ou igual a | 2 >= 2 | verdadeiro |
< | Menor que | 2 < 3 | verdadeiro |
<= | Menor que ou igual a | 2 <= 3 | verdadeiro |
Verdadeiro e falso
Todos os valores no JavaScript são implicitamente true
ou false
e podem ser forçados para
o valor booleano correspondente. Por exemplo, usando o comparador "loosely equal". Um conjunto limitado de valores é forçado a false
:
0
null
undefined
NaN
- Uma string vazia (
""
)
Todos os outros valores são convertidos em true
, incluindo qualquer string que contenha um ou mais
caracteres e todos os números diferentes de zero. Eles são comumente chamados de valores "verdadeiros" e
"falsos".
"My string" == true
> true
100 == true
> true
0 == true
> false
Operadores lógicos
Use os operadores lógicos AND (&&
), OR (||
) e NOT (!
) para controlar o fluxo de um script com base na avaliação de duas ou mais instruções condicionais:
2 === 3 || 5 === 5;
> true
2 === 2 && 2 === "2"
> false
2 === 2 && !"My string."
> false
Uma expressão lógica NOT (!
) nega o valor verdadeiro ou falso de um operando, avaliando true
se o operando for false
e false
se o operando for true
:
true
> true
!true
> false
!false
> true
Usar o operador lógico NOT (!
) em outro tipo de dados, como um
número ou uma string, força esse valor a um booleano e inverte o valor verdadeiro ou
falso do resultado.
"string"
> "string"
!"string"
> false
0
> 0
!0
> true
É uma prática comum usar dois operadores NOT para forçar rapidamente os dados a corresponder ao valor booleano correspondente:
!!"string"
> true
!!0
> false
Os operadores lógicos AND e OR não realizam coerção por conta própria. Elas retornam o valor de um dos dois operandos que estão sendo avaliados, com o operando escolhido determinado por essa avaliação.
A operação lógica AND (&&
) retorna o primeiro dos dois operandos somente se esse operando
for avaliado como false
. Caso contrário, o segundo operando será retornado. Em comparações que
são avaliadas como valores booleanos, ele retorna true
somente se os operandos em ambos os lados
do E lógico forem avaliados como true
. Se qualquer lado for avaliado como false
, ele retornará false
.
true && false
> false
false && true
> false
false && false
> false
true && true
> true
Quando &&
é usado com dois operandos não booleanos, o primeiro operando é retornado
inalterado se puder ser forçado para false
. Se o primeiro operando puder ser forçado
a true
, o segundo operando será retornado inalterado:
false && "My string"
> false
null && "My string"
> null
"My string" && false
> false
"My string" && "My second string"
> "My second string"
2 === 2 && "My string"
> "My string"
A operação OR lógica (||
) retorna o primeiro dos dois operandos somente se esse operando
for avaliado como true
. Caso contrário, o segundo operando será retornado. Em comparações que
são avaliadas como valores booleanos, isso significa que o método retorna true
se um dos operandos
for avaliado como true
. Se nenhum lado for avaliado como true
, ele retornará
false
:
true || false
> true
false || true
> true
true || true
> true
false || false
> false
Ao usar ||
com dois operandos não booleanos, ele retorna o primeiro operando
inalterado se ele puder ser forçado para true
. Se o primeiro operando puder ser forçado
a false
, o segundo operando será retornado inalterado:
false || "My string"
> "My string"
null || "My string"
> "My string"
"My string" || false
> "My string"
"My string" || "My second string"
> "My string"
2 === 2 || "My string"
> true
Operador de coalescência nulo
Introduzido no ES2020,
o "operador de coalescência nulo" (??
) retorna o primeiro operando somente se ele
tiver qualquer valor diferente de null
ou undefined
. Caso contrário, ele retorna
o segundo operando.
null ?? "My string"
> "My string"
undefined ?? "My string"
> "My string"
true ?? "My string";
> true
??
é semelhante a uma operação lógica OR, mas é mais rigoroso na forma como o primeiro operando é
avaliado. ||
retorna o segundo operando para qualquer expressão que possa ser
forçada para false
, incluindo undefined
e null
. ??
retorna o segundo
operando somente quando o primeiro é estritamente igual a null
ou undefined
,
mesmo que possa ser forçado a false
:
0 ?? "My string";
> 0
false ?? "My string";
> false
undefined ?? "My string";
> "My string"
Operadores de atribuição lógica
Use operadores de atribuição para atribuir o valor de um segundo operador a um primeiro
operador. O exemplo mais comum é um único sinal de igual (=
), usado para
atribuir um valor a uma variável declarada.
Use operadores de atribuição lógica para atribuir condicionalmente um valor a uma variável com base no valor verdadeiro ou falso dela.
O operador de atribuição lógica E (&&=
) avalia o segundo operando e
o atribui ao primeiro se o primeiro for avaliado como
true
. Ou seja, "se o primeiro operando for verdadeiro, atribua o valor do
segundo operando:"
let myVariable = false;
myVariable &&= 2 + 2;
> false
myVariable = true;
myVariable &&= 2 + 2;
> 4
O valor verdadeiro ou falso do primeiro operando determina se uma atribuição
é realizada. No entanto, tentar avaliar o primeiro operando usando um operador de comparação
resulta em um booleano true
ou false
, que não pode ser atribuído a um
valor:
let myVariable = 5;
myVariable > 2 &&= "My string"
> SyntaxError: Invalid left-hand side in assignment
O operador de atribuição lógica OR (||=
) avalia o segundo operando e
o atribui ao primeiro se ele for false
.
Ou seja, "se o primeiro operando for falso, atribua o valor do segundo
operando:"
let myVariable = false;
myVariable ||= 2 + 2;
> 4
myVariable = true;
myVariable ||= 2 + 2;
> true
Teste seu conhecimento
Qual operador indica "estritamente igual"?
===
==
=
!=