Skip to content

gloriateodoro/On9-Accenture-S2-Logica

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

On9-Accenture-S2-Logica

Lógica - Variáveis, Operadores e Condicional

Objetivos

Entender os princípios básicos de lógica de programação utilizando a linguagem JavaScript

Quem é o JavaScript na fila do pão?

JavaScript é uma linguagem de programação que permite a você implementar itens complexos em páginas web — toda vez que uma página da web faz mais do que simplesmente mostrar a você informação estática — mostrando conteúdo que se atualiza em um intervalo de tempo, mapas interativos ou gráficos 2D/3D animados, etc. — você pode apostar que o JavaScript provavelmente está envolvido. É a terceira camada do bolo das tecnologias padrões da web, duas das quais (HTML e CSS) nós falamos com muito mais detalhes em outras partes da Área de Aprendizado.

referência: MDN

A linguagem JavaScript também é utilizada para criar aplicações backend (que é o foco do nosso curso). O Node.js é um ambiente de execução Javascript server-side Você pode aprender um pouco mais sobre o que é o Node e como ele funciona aqui.

Dica 💡

HTML e CSS são linguagens de marcação. Linguagens de marcação são usadas para descrever e definir elementos dentro de um documento. JavaScript é uma linguagem de programação. Linguagens de programação são usadas para comunicar instruções a uma máquina. Elas podem ser usadas para controlar o comportamento de uma máquina e expressar algoritmos.

História do JavaScript

HipstersPontoTube

Navegadores e ferramentas de desenvolvimento

Google Chrome

As ferramentas do desenvolvedor do Chrome são um conjunto de ferramentas de autoria e depuração internas do Google Chrome. Use as ferramentas do desenvolvedor para iterar, depurar e analisar seu site. Para saber mais, clique aqui.

Para abrir as ferramentas do desenvolvedor do Chrome, clique com o botão direito do mouse em qualquer elemento da página e selecione Inspect ou abra o menu do Chrome, no canto superior direito da janela de seu navegador, e selecione More Tools > Developer Tools. Como alternativa, você pode usar os seguintes atalhos:

Command (⌘) + Option + i (Mac)

Ctrl + Shift (⇧) + i (Windows/Linux).

Atalhos de teclado das ferramentas de desenvolvedor do Chrome

Mozilla Firefox

As ferramentas do desenvolvedor do Firefox permitem que você examine, edite e depure HTML, CSS e JavaScript no desktop e no celular. Além disso, você pode baixar uma versão do Firefox chamada Firefox Developer Edition, que é personalizada para desenvolvedores, apresentando os últimos recursos do Firefox e ferramentas do desenvolvedor experimentais. Para saber mais, clique aqui.

Para abrir as ferramentas do desenvolvedor do Firefox, clique com o botão direito do mouse em qualquer elemento da página e selecione Inspect Element ou abra o menu do Firefox, no canto superior direito da janela de seu navegador, e selecione Developer. Como alternativa, você pode usar os seguintes atalhos:

Command (⌘) + Option + i (Mac)

Ctrl + Shift (⇧) + i (Windows/Linux).

console.log

console.log é um comando usado para exibir conteúdo para o console do JavaScript. Rode o seguinte código no console:

console.log("Olá mundo!");

Parabéns! Você realizou a ação de log no console de depuração.

A mensagem que você registrou é "Olá mundo!". Olá mundo! é uma string (uma sequência de caracteres).


O que é um Algoritmo?

A resposta para essa pergunta é mais simples do que parece algoritmos são uma sequência de ações finitas que levam a determinado um resultado.

Ou seja, é uma forma automática de fazer as coisas, como, por exemplo, levantar da cama e se preparar para então começar um dia de trabalho ou seguir todos os dias o mesmo caminho e pegar o mesmo ônibus para chegar a um determinado ponto. É um passo a passo de ações. Assim funciona um algoritmo.

Algoritmo básico para assar um pão:

Fluxograma

Dica 💡

Jogo para treinar algoritmos: Lighbot. Faça o robozinho andar e acender a luzinha. Você vai perceber que o computador faz apenas aquilo que você manda.😼

💡Ada Lovelace, a primeira programadora de todos os tempos


Tipos de dados e variáveis

Números

Definir um número em JavaScript é, na verdade, bem simples. O tipo de dado number inclui qualquer inteiro positivo ou negativo, bem como decimais. Inserir um número no console fará com que o mesmo valor seja retornado para você

Operações aritméticas

Você também pode fazer cálculos com números de maneira bem fácil. Basicamente, digite uma expressão da mesma maneira que você a digitaria em uma calculadora.

3 + 2.1

Returns: 5.1

Agora é sua vez!

Insira as expressões (uma de cada) no console e determine o resultado de cada uma.

2 + 10 - 19 + 4 - 90 + 1

-20 + -19 - (-10) - (-1) + 24

(10/5) \* 4 - 20

4096 % 12

Comparando números

E quanto à comparação de números? Você consegue fazer isso? Mas é claro que consegue!

Assim como na matemática, você pode comparar dois números para verificar se um é maior, menor ou igual ao outro.

5 > 10

Returns: false

5 < 10

Returns: true

5 == 10

Returns: false

Comparações entre números irá resultar em verdadeiro ou falso. Veja na tabela abaixo outros exemplos de comparações que podemos fazer:

Operadores lógicos
Operador Significado
< Menor que
> Maior que
<= Menor ou igual a
>= Maior ou igual a
== Igual a
!= Diferente de
Agora é com você

Quizz: https://app.sli.do/event/mh6zxmqx

String

String é uma sequência de caracteres usados para representar texto.

"Variáveis em Javascript são uma forma para se salvar dados";

"Reprograma";

"1 é um número ímpar";
Concatenação de strings

Strings são uma coleção de caracteres agrupados entre aspas simples ou duplas. Você pode utilizar strings para representar dados como frases, nomes, endereços e mais.

Você sabia que é possível até mesmo somar strings? Em JavaScript, isso é chamado de concatenação. Concatenar duas strings é, na verdade, bem simples!

"Hello," + " New York City"

Retorna: "Hello, New York City"

Você verá outras maneiras de fazer concatenação e fazer até mais coisas com strings mais adiante neste curso. Mas, por agora, pratique utilizando o operador de adição +.

Agora é com você!

Quizz

Boolean

é um tipo de dado lógico que pode ter apenas um de dois valores possíveis: verdadeiro ou falso.

false;
true;

Null

representa um valor nulo ou "vazio".

var y = null;
console.log(y);

null

Variáveis

Uma variável é um container para um valor, como um número que podemos usar em uma operação de adição, ou uma sequência de texto que possamos usar como parte de uma frase. Mas uma coisa especial a respeito das variáveis é que seu conteúdo pode mudar.

Três caixas azuis. Cada uma tem algo dentro. A primeira, o nome Bob. A segunda, o falor true. A terceira o número 35.

Toda vez que precisarmos armezanar e recuperar dados utilizaremos variáveis.

No Javascript temos 3 maneiras de usar variáveis:

  • var (no console vamos usar essa)
  • let
  • const
var numero = 1;
var texto = "Vamos reprogramar o mundo no domingo.";
Convenções de nomenclatura

Quando cria uma variável, você escreve o nome da variável utilizando camelCase (a primeira palavra em minúsculo e as palavras seguintes, em maiúsculo).

Também tente utilizar um nome de variável que, de maneira precisa, porém sucinta, descreve do que aquele dado se trata.

var totalAfterTax = 53.03; // utiliza camelCase se o nome da variável tiver múltimas palavras
var tip = 8; // utiliza letras minúsculas se o nome da variável tiver somente uma palavra
var firstName = "Pabllo";
var counter = 1;

Não utilizar camelCase no nome de suas variáveis não vai, necessariamente, danificar alguma coisa em JavaScript.

Porém, existem guias de estilo recomendados para todas as linguagens de programação que ajudam a manter o código consistente, limpo e fácil de ser lido.

Isso é especialmente importante quando trabalhamos com projetos maiores, que serão acessados por diversas pessoas desenvolvedoras.

Você pode ler mais sobre o Guia de Estilo JavaScript do Google aqui.

Declarando variáveis

Um identificador JavaScript deve começar com:

  • uma letra
  • underline (_)
  • cifrão ($)

Os caracteres subsequentes podem também ser

  • números (0-9)
  • letras incluem caracteres de "A" a "Z" (maiúsculos)
  • caracteres de "a" a "z" (minúsculos)

Uma variável não pode ser uma palavra reservada, clique aqui para saber quais são

Exercício extra: https://developer.mozilla.org/pt-BR/docs/Learn/JavaScript/First_steps/Teste_suas_habilidades:_variaveis


Ferramentas para receber dados de maneira interativa

O alert mostra uma mensagem na tela como um pop-up.

var mensagem = "Mensagem que vai aparecer no nosso alerta";
alert(mensagem);

O confirm é um pop-up que oferece uma lógica através de dois botões - o Ok (true) e o Cancel (false)`

var mensagem = "Aperte o botão ok";
confirm(mensagem);
// Se o usuário apertar Ok vai retornar true, se apertar Cancel vai retornar false

O prompt é um pop-up que nos oferece um input para coletarmos variáveis.

var pergunta = "Digite o seu nome";
prompt(pergunta);
// TODO - por que o prompt retorna string e como fizemos para tratar isso
Exercício guiado

Vamos fazer um programa que peça dois números e imprima no console a soma desses dois números.

Agora é com você

Escreva um programa que receba um valor em metros e o exiba no console convertido em milímetros


Operadores aritméticos e lógicos

Operadores de atribuição

O operador de atribuição básico é o igual (=), que atribui o valor do operando à direita ao operando à esquerda.

Exemplo:

var diaDaSemana = "domingo";

diaDaSemana = "segunda";

console.log(diaDaSemana); // segunda

Isto é, x = y atribui o valor de y a x.

Igual

const y = 7;
const x = y; // x é igual à 7

Operadores Aritméticos

Adição (+)
const y = 7;
const x = 3;

const resultado = y + x;
console.log(resultado); // 10
Subtração (-)
const y = 5;
const x = 2;
const resultado = y - x;
console.log(resultado); // 3
Multiplicação(_)
const y = 4;
const x = 5;
const resultado = y _ x
console.log(resultado) // 20
Divisão (/)

O operador de divisão produz o quociente de seus operandos onde o operando da esquerda é o dividendo e o da direita é o divisor.

const y = 10;
const x = 2;
const resultado = y / x;
console.log(resultado); // 5
Módulo (%)

O operador módulo retorna o resto inteiro da divisão de um numero pelo outro.

const y = 10;
const x = 2;
const resultado = y % x;
console.log(resultado); // 0
Operadores de Comparação - Relacional e Igualdade
== Igual

Retorna verdadeiro caso os operandos sejam iguais.

3 == 3; // true
"3" == 3; // true
3 == "3"; // true
!= Não igual (diferente)

Retorna verdadeiro caso os operandos não sejam iguais.

5 != 4; // true
"4" != "3"; // true
=== Estritamente igual

Retorna verdadeiro caso os operandos sejam iguais e do mesmo tipo. Veja também Object.is e igualdade em JS.

3 === "3"; // false

!== Estritamente não igual (diferente)

Retorna verdadeiro caso os operandos não sejam iguais e/ou não sejam do mesmo tipo.

3 !== "3"; // true
3 !== "3"; // true

O double equals vai tentar nos ajudar na comparação, e ao notar que estamos tentando comparar tipos diferentes (string e number) ele vai tentar converter a string para number. No caso acima ele consegue e por isso temos o resultado true.

Entao por baixo dos panos o que aconteceu foi:

2 == Number("2") //true

Com o triple equals o JavaScript nunca tenta converter os valores. Por isso, o resultado false.

Sendo assim, recomenda-se usar o triple equals para evitar surpresas.

E a internet não perdoa as surpresas:

Patrick agindo como o Javascript ao fazer comparações estritas ou fracas

Dica

Saiba mais sobre coerção implícita do javascript

> maior que

O operador de Maior retorna true se o operando da esquerda for maior que o operando da direita.

4 > 3 // true
>= maior ou igual a

O operador maior ou igual retorna true se o operando da esquerda for maior ou igual ao operando da direita.

4 >= 3 // true
3 >= 3 // true
< menor que

O operador menor retorna true (verdadeiro) se o operando da esquerda for menor que o operando da direita.

3 < 4 // verdade
<= menor ou igual a

O operador menor ou igual retorna true (verdadeiro) se o operando da esquerda for menor ou igual ao operando da direita.

3 <= 4 // verdade

Operadores Lógicos

&& E lógico

Se o primeiro valor for verdadeiro, ou puder ser considerado ou convertido pra verdadeiro retorna o segundo valor.

Se for feriado e estiver sol, vou à praia.

É feriado? Sim. Está sol? Sim. 🏖️

É feriado? Não. Está Sol? Sim. 🏠

Se o primeiro valor for falso, retorna falso.

true && "oi" // "oi"
"oi" && true // true
true && false // false
|| Ou lógico

Se o primeiro valor for verdadeiro, ou puder ser considerado ou convertido pra verdadeiro retorna o primeiro valor.

Se for feriado ou estiver sol, vou à praia.

É feriado? Sim. Está sol? Não. 🏖️🌧️

É feriado? Não. Está sol? Sim. 🏖️👀

Se o primeiro valor for falso, retorna o segundo valor.

false || true // true
false || false // false
false || "oi" // "oi"
false || 0 // 0
! Não lógico

Esse operador inverte o valor de uma expressão

Obs: Se um valor pode ser convertido para verdadeiro, este valor é chamado de truthy. Se um valor pode ser convertido para falso, este valor é chamado de falsy.

Exemplos de expressões que podem ser convertidas para falso são:

  • null;
  • NaN;
  • 0;
  • string vazia ("");
  • undefined.

Todos os outros são considerados verdadeiros.

!true // false
!false // true
!'Oi' // false
!'' // true

Condicionais

Usamos para verificar uma condição e definir se algo deve ou não acontecer a partir da condição dada.

É a linguagem que utilizamos para nos comunicar, repare:

Se amanhã fizer sol, vou viajar para a praia.

Temos uma condição (Se amanhã fizer sol) para executar uma ação (viajar para a praia) dependendo do resultado dessa condição. Se verdadeira, a ação é executada.

Expressões condicionais simples

// Variável booleana verdadeira
const sol = true;

// Condição
if ( sol ) {
	// Ação
	console.log('Vou viajar para a praia!');
}

Estrutura if / else

// Variável booleana verdadeira
const sol = false;

// Condição
if ( sol ) {
	// Ação
	console.log('Vou viajar para a praia!');
}else{
	// Ação
	console.log('Vou ao cinema');
}

Estrutura if / else if / else

// Variável booleana verdadeira
const hora = 8;

// Condição
if ( hora <= 12 ) {
	// Ação
	console.log('Bom dia');
}else if( hora <= 18){
	// Ação
	console.log('Boa tarde');
}else{
	// Ação
	console.log('Boa noite');
}
if ( condição ) {
	// Ação
} else if ( outra condição ) {
	// Ação
} else if ( outra condição ) {
	// Ação
} else if ( outra condição ) {
	// Ação
} else if ( quantas condições quiser ) {
	// Ação
} else {
	// Ação final se nenhuma condição for verdadeira
}

Estrutura switch

switch (expression) {
  case choice1:
    run this code
    break;

  case choice2:
    run this code instead
    break;
    
  // include as many cases as you like

  default:
    actually, just run this code
}

Dica

Tomando decisões no seu código — condicionais

Exercício guiado

Vamos escrever um programa que receba um número digitado no prompt

Então, se o número for múltiplos de 3 o console imprimirá a palavra “Fizz” .

Se for múltiplo de 5 mostraremos “Buzz”.

Agora, se ele for múltiplo de 3 e 5 mostre “FizzBuzz”.

Agora é com você:

Receba uma palavra pelo prompt e diga se essa palavra começa com uma vogal. Imprima sim ou não no console.

About

Lógica - Variáveis, Operadores e Condicional

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%