You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web-Dev-For-Beginners/2-js-basics/3-making-decisions/translations/README.pt.md

8.4 KiB

Noções básicas de JavaScript: Tomando Decisões

Noções básicas de JavaScript - Tomando Decisões

Sketchnote by Tomomi Imura

Quiz Pré-Aula

Quiz Pré-Aula

Tomar decisões e controlar a ordem do que é executado no seu código o torna recusável e robusto. Essa seção cobre a sintaxe para controle do fluxo de dados no JavaScript e sua significância quando usada com tipos Booleanos.

Tomando Decisões

🎥 Clique na imagem acima para ver um video sobre tomada de decisões (Em Inglês)

Você pode fazer essa aula em Microsoft Learn! (Em Inglês)

Uma breve recapitulação sobre Booleanos

Booleanos podem ter apenas dois valores true ou false (Verdadeiro ou falso). Os booleanos ajudam a tomar decisões sobre quais linhas de código devem ser executadas quando certas condições são atendidas.

Atribua valores verdadeiro ou falso no seu booleano da seguinte forma:

let meuBooleanoVerdadeiro = true let meuBooleanoFalso = false

Os booleanos receberam o nome do matemático, filósofo e lógico inglês George Boole (18151864).

Operadores de comparação e booleanos

Os operadores são usados para avaliar as condições fazendo comparações que criarão um valor booleano. A seguir está uma lista de operadores que são usados com frequência

Simbolo Descrição Exemplo
< Menor que: Compara dois valores e retorna o tipo de dados Booleano true se o valor do lado esquerdo for menor que o direito 5 < 6 // true
<= Menor ou igual: Compara dois valores e retorna o tipo de dados Booleano true se o valor à esquerda for menor ou igual à direita 5 <= 6 // true
> Maior que: Compara dois valores e retorna o tipo de dados Booleano true se o valor à esquerda for menor ou igual à direita 5 > 6 // false
>= Maior ou igual: Compara dois valores e retorna o tipo de dados Booleano true se o valor à esquerda for maior ou igual à direita 5 >= 6 // false
=== Igualdade estrita: Compara dois valores e retorna o tipo de dados booleano true se os valores à direita e à esquerda forem iguais E forem do mesmo tipo de dados. 5 === 6 // false
!== Desigualdade: Compara dois valores e retorna o valor booleano oposto ao que um operador de igualdade estrita retornaria 5 !== 6 // true

Verifique seu conhecimento escrevendo algumas comparações no console do seu navegador. Algum dado retornado o surpreende?

Instrução If

A instrução if executará o código entre seus blocos se a condição for verdadeira.

if (condição){
    // A condição era verdadeira. O código neste bloco será executado.
}

Os operadores lógicos são freqüentemente usados para formar a condição.

let dinheiroAtual;
let precoLaptop;

if (dinheiroAtual >= precoLaptop){
    // A condição era verdadeira. O código neste bloco será executado.
    console.log("Comprando um novo laptop!");
}

Instrução IF..Else

A instrução else executará o código entre seus blocos quando a condição for falsa. É opcional com uma instrução if.

let dinheiroAtual;
let precoLaptop;

if (dinheiroAtual >= precoLaptop){
    // A condição era verdadeira. O código neste bloco será executado.
    console.log("Comprando um novo laptop!");
}
else{
    // A condição era verdadeira. O código neste bloco será executado.
    console.log("Ainda não posso comprar um novo laptop!");
}

Teste sua compreensão deste código e do código a seguir, executando-o em um console de navegador. Altere os valores das variáveis dinheiroAtual e precoLaptop para alterar os retornos do console.log ().

Operadores Lógicos e Booleanos

As decisões podem exigir mais de uma comparação e podem ser combinadas com operadores lógicos para produzir um valor booleano.

Simbolo Descrição Exemplo
&& AND Lógico: Compara duas expressões booleanas. Retorna verdadeiro ** apenas ** se ambos os lados forem verdadeiros (5 > 6) && (5 < 6 ) //// Um lado é falso, o outro é verdadeiro. Retorna falso
|| OR Lógico: Compara duas expressões booleanas. Retorna verdadeiro se pelo menos um lado for verdadeiro `(5> 6) \
! NOT Lógico: Retorna o valor oposto de uma expressão booleana ! (5> 6) // 5 não é maior que 6, mas"! " retornará verdadeiro

Codições e Decisões com Operadores Lógicos

Operadores lógicos podem ser usados para formar condições em instruções if..else.

let dinheiroAtual;
let precoLaptop;
let laptopComDesconto = precoLaptop - (precoLaptop * .20) //Laptop com desconto de 20%

if (dinheiroAtual >= precoLaptop || dinheiroAtual >= laptopComDesconto){
    // A condição era verdadeira. O código neste bloco será executado.
    console.log("Comprando um novo laptop!");
}
else {
    // A condição era verdadeira. O código neste bloco será executado.
    console.log("Ainda não posso comprar um novo laptop!");
}

Operador de negação

Você viu até agora como se pode usar uma instrução if ... else para criar lógica condicional. Tudo o que entra em um if precisa ser avaliado como verdadeiro / falso. Usando o operador ! Você pode negar a expressão. Seria assim:

if (!condicao) {
  // é executado se a condição for falsa
} else {
  // é executado se a condição for verdadeira
}

Expressões ternárias

if ... else não é a única maneira de expressar a lógica de decisão. Você também pode usar algo chamado operador ternário. A sintaxe é assim:

let variavel = condicao ? <retorne isso se verdadeiro> : <retorne isso se falso>

Abaixo está um exemplo mais tangível:

let primeiroNumero = 20;
let segundoNumero = 10
let maiorNumero = primeiroNumero > segundoNumero ? primeiroNumero: segundoNumero;

Reserve um minuto para ler este código algumas vezes. Você entende como esses operadores estão trabalhando?

O código acima afirma que

  • Se primeiroNumero for maior que o segundoNumero
  • então atribua primeiroNumero a maiorNumero
  • Senão atribua segundoNumero.

A expressão ternária é apenas uma forma compacta de escrever o código abaixo:

let maiorNumero;
if (primeiroNumero > segundoNumero) {
  maiorNumero = primeiroNumero;
} else {
  maiorNumero = segundoNumero;
}

🚀 Desafio

Crie um programa que seja escrito primeiro com operadores lógicos e, em seguida, reescreva-o usando uma expressão ternária. Qual é a sua sintaxe preferida?


Quiz Pós-Aula

Quiz Pós Aula

Revisão e autoestudo

Leia mais sobre os vários operadores disponíveis para o usuário no MDN.

Vá até a maravilhosa pesquisa de operador! de Josh Comeau

Tarefa

Operadores