🤔╺╸Aprendendo JavaScript | Operadores Lógicos #8

Opa! Agora escreverei sobre Operadores Lógicos em JavaScript. Esses operadores verificam a veracidade de duas sentenças, retornando um Boolean no final.

Tabela Verdade

&&

O operador "and" retorna um bool de acordo com a tabela:

bool bool return
V V V
V F F
F V F
F F F

||

O operador "or" retorna um bool de acordo com a tabela:

bool bool return
V V V
V F V
F V V
F F F

Funcionamento Prático

&&

let teste;
if ((1 < 2) && (4 > 5)) { // and: V + F = F
    teste = true;
} else {
    teste = false;
}

console.log(teste) // false

||

let teste;
if ((1 < 2) || (4 > 5)) { // or: V + F = V
    teste = true;
} else {
    teste = false;
}

console.log(teste) // true

Conclusão

Esses operadores são de suma importância quando trata-se de estruturais condicionais que possuem mais de uma condição. Se você que leu até aqui tiver alguma dica, crítica ou apoio para comentar, comente! Obrigado por ler até aqui e até o próximo post!

Segundo a especificação da linguagem esses são os Binary Logical Operators. Um detalhe importante é que em JavaScript o resultado não necessariamente é um valor booleano, pois esses operadores sempre retornam o valor de um dos operandos.

Isso porque em JavaScript qualquer valor pode ser usado em um contexto booleano. Existem os chamados truthy values e falsy values, ou seja, valores que são considerados true ou false quando usados em um contexto booleano. Basicamente, o número zero, "" (string vazia), null, undefined e NaN são considerados falsos (além, é claro, do próprio booleano false), e qualquer outro valor é considerado verdadeiro.

Ou seja, se eu tiver algo como console.log('a' || 20), isso irá imprimir a string "a" (pois ela é considerada true, e o operador || retorna o primeiro operando se este for true, caso contrário retorna o segundo). E console.log('a' && 20) imprime 20, pois o operador && retorna o primeiro operando se este for false, caso contrário retorna o segundo.

Por isso é comum ter coisas como:

x = valor1 || valor2 || valor3;

Ou seja, x recebe o primeiro dos valores que não for falsy (ou o último, caso todos sejam). Isso só é possível porque o operador retorna um dos operandos, ou seja, ao final é garantido que algum dos valores será atribuído a x. Seria equivalente a isso:

if (valor1) {
    x = valor1;
} else if (valor2) {
    x = valor2;
} else {
    x = valor3;
}

Repare que o último não precisa testar, pois se chegou ali é porque todos os anteriores são falsy values e o retorno será valor3 de qualquer jeito.


Outro detalhe importante é que esses operadores são "short-circuit", ou seja, nem sempre ambos os operandos serão avaliados.

No caso do ||, se um dos operandos é verdadeiro, então a expressão toda será. Por isso, se o primeiro for verdadeiro, ele nem avalia o segundo. Exemplo:

function primeiro() {
    console.log('primeiro');
    return 1;
}
function segundo() {
    console.log('segundo');
    return 2;
}

if (primeiro() > 0 || segundo() > 0) {
    console.log('ok');
}

A saída deste código é:

primeiro
ok

Ou seja, ele avaliou a primeira condição (verifica se o retorno da função primeiro() é maior que zero), e como esta é verdadeira, ele nem precisou avaliar a segunda.

De forma similar, o operador && é verdadeiro apenas se ambos os operandos também forem verdadeiros. Então se o primeiro for falso, ele nem avalia o segundo:

function primeiro() {
    console.log('primeiro');
    return 1;
}
function segundo() {
    console.log('segundo');
    return 2;
}

if (primeiro() < 0 && segundo() > 0) {
    console.log('ok');
}

Agora ele avalia a expressão primeiro() < 0, e como o resultado é falso, o resultado do operador é false e ele nem avalia a segunda expressão. Por isso a saída é apenas:

primeiro
Novamente, muito obrigado! Agora entendi de fato a lógica por trás dos operadores, graças a você. Seus comentários são muito pertinentes, continue!!!

Tem mais um operador, o ?? (nullish coalescing operator), que foi adicionado recentemente ao JavaScript. Ele é semelhante ao ||, mas funciona de forma diferente ao verificar se um valor é "válido" ou não.

O operador || segue o padrão falsy, o que significa que ele considera 0, '' (string vazia), false, null, undefined, e NaN como valores falsy. Por exemplo:

const var1 = 0 || 10
console.log(var1) // O resultado será 10, pois 0 é considerado falsy.

Por outro lado, o ?? só considera null e undefined como falsy. Qualquer outro valor é considerado "válido". Por exemplo:

const var1 = 0 ?? 10
console.log(var1) // O resultado será 0, pois o ?? considera 0 como um valor válido.

Portanto, se você quer usar o operador ||, mas deseja que ele considere valores como 0, false, e '' como válidos, você pode usar o ??. Espero ter ajudado!

Nossa, que interessante! Vou pesquisar mais sobre, obrigado pela observação!