/On9-Accenture-S4-Logica

Lógica - Objetos, Arrays e Métodos

Primary LanguageJavaScript

On9-Accenture-S4-Logica

Lógica - Objetos, Arrays e Métodos

Introdução

Até este momento do curso, trabalhamos com diversos tipos de dados, Strings, números, booleans... Mas como lidar com muitos dados de uma só vez?

Vamos imaginar que temos uma sorveteria e precisaremos gerenciar os mais diversos sabores que vamos vender na loja.

Sorvetes

Coco
Maracujá
Abacaxi
Baunilha
Tangerina
Doce de Leite
Iogurte de frutas vermelhas
Melancia
Chocolate
Chocolate Belga
Torta de limão
Sensação
Amendoim
Milho
... e contando...

Muitos sabores, não?

Será que existe um jeito de armazenar tudo em um lugar ou em uma variável, onde poderíamos ter tipo uma lista com todos os sorvetes?🤔

Rá, existe este jeito! Podemos armazenas estas informações todas em uma estrutura de dados chamada Array!

Array é uma estrutura de dados que pode carregar múltiplos valores de dados, de maneira organizada, como se fosse uma lista.

Como criar um Array?

Para declarar um array em Javascript, podemos fazer da seguinte maneira:

let sorvetes = [];

os [] vazios significam que a variável sorvete é, neste momento um array vazio.

Vamos agora então colocar todos os sabores de sorvete da nossa loja dentro do array!

Note que nessa estrutura de dados, cada item é separado por virgulas.

let sorvetes = [
  "Coco",
  "Maracujá",
  "Abacaxi",
  "Baunilha",
  "Tangerina",
  "Doce de Leite",
  "Iogurte de frutas vermelhas",
  "Melancia",
  "Chocolate",
  "Chocolate Belga",
  "Torta de limão",
];

Apesar de termos feito uma lista com os sabores, strings não são o único tipo de dado que você pode armazenar em uma array. Você também pode armazenar números, booleanos... e, na verdade, qualquer coisa!

// cria o array `mixedData` com tipos de dados variados
var mixedData = ["abcd", 1, true, undefined, null, "todas as coisas"];

Você também pode mesmo armazenar uma array dentro de outra, criando uma array aninhada! Arrays aninhadas podem ser particularmente difíceis de ler, então, é comum escrevê-las em uma linha, usando uma nova linha após cada vírgula:

// cria uma array `arraysInArrays`, composta de três arrays
var arraysInArrays = [
  [1, 2, 3],
  ["Julia", "James"],
  [true, false, true, false],
];

Acessando os elementos de uma array

O index, em um array é o endereço ou posição de um elemento.

Vamos voltar um pouco na aula anterior, quando falamos rapidamente sobre strings:

vamos criar uma variável nome e atribuir um valor a ela:

let nome = "reprograma";

Uma string também pode ser considerada como um array onde cada elemento é um caracter, certo?

index 0 1 2 3 4 5 6 7 8 9
item r e p r o g r a m a

Acessando a primeira letra da variável nome:

console.log(nome[0]);
// imprime a letra 'r'

Isso significa que no nosso array de sorvetes podemos utilizar a mesma propriedade para acessar um sabor específico!

index item
0 Coco
1 Maracujá
2 Abacaxi
3 Tangerina
4 Doce de Leite
5 Iogurte de frutas vermelhas
6 Melancia
7 Chocolate
8 Chocolate Belga
9 Torta de Limão
console.log(sorvetes[8]);
// Chocolate Belga

Lembre-se de que os elementos de uma array são indexados começando na posição 0. Para acessar um elemento em uma array, use o nome da array imediatamente seguido pelos colchetes contendo o índice do valor que você quer acessar.

Se você tentar acessar um elemento em um índice que não existe, um valor de indefinido será retornado.

console.log(sorvetes[10]);
// undefined

Mudando o valor de um elemento do array

Se você quiser mudar um valor de um elemento em um array, você pode fazê-lo definindo ele como igual a um novo valor.

sorvetes[1] = "Baunilha";
console.log(sorvetes[1]);
// imprime "Baunilha"

Métodos e propriedades de Arrays

O JavaScript fornece um grande número de métodos para modificar arrays e acessar valores dentro dela. Veja a documentação MDN, ou digite []. no console do browser, para ver uma lista de todos os métodos para array disponíveis.

Length

Você pode descobrir o tamanho de uma array usando sua propriedade length.

let sorvetes = ["Coco", "Abacaxi", "Baunilha"];
console.log(sorvetes.length());
// imprime 3

Push

Você pode usar o método push() para adicionar elementos ao fim de um array.

Por exemplo, imagine a seguinte distribuição de sorvetes:

let sorvetes = ["Limão", "Doce de Leite", "Cookie"];
console.log(sorvetes.length());
// imprime 3

Então, você adicionar um novo sabor na última posição do array usando o método push().

sorvetes.push("Baunilha")''
//retorna 7
console.log(sorvetes)
// ["Limão", "Doce de Leite", "Cookie", "Baunilha"];

Observe que, com o método push(), você precisa passar o valor do elemento que quer adicionar ao fim da array. O método push() também retorna o tamanho da array após um elemento ser adicionado.

Pop

Você pode usar o método pop() para remover elementos do fim de uma array.

let sorvetes = ["Limão", "Doce de Leite", "Cookie", "Baunilha"];

sorvetes.pop(); //retira "Baunilha" da última posição do array sorvetes
sorvetes.pop(); //retira "Cookie" da última posição do array sorvetes
sorvetes.pop(); //retira "Doce de Leite" da última posição do array sorvetes

// Retorna "Doce de Leite"

Com o método pop() você não precisa passar um valor; em vez disso, pop() sempre removerá o último elemento do fim de uma array. pop() também retorna o elemento que foi removido, no caso de você precisar usá-lo.

Splice

splice() é um outro método acessível que permite que você adicione e remova elementos de qualquer lugar dentro de uma array.

Enquanto push() e pop() limitam-se a adicionar e remover elementos do fim de um array, splice() permite especificar a localização do índice para adicionar novos elementos, bem como o número de elementos que você gostaria de excluir (se existir algum).

let sorvetes = ["Morango", "Abacaxi", "Maracujá"];
sorvetes.splice(1, 1, "Abacaxi com coco", "Manga");

// Retorna Abacaxi

console.log(sorvetes);
// [ 'Morango', 'Abacaxi com coco', 'Manga', 'Maracujá' ]

Estado inicial do array:

Morango Abacaxi Maracuja

Estado final após o splice()

Morango Abacaxi com coco Manga Maracuja

O primeiro argumento representa o índice inicial de onde você quer alterar a array, o segundo argumento representa o número de elementos que você quer remover e o restante dos argumentos representam os elementos que você quer adicionar.


Loops & Arrays

Uma vez que o dado está na array, você quer ser capaz de eficientemente acessar e manipular cada elemento da array sem escrever código repetitivo para cada elemento.

Por exemplo, se esta fosse nossa array sorvetes original:

let sorvetes = ["Chocolate", "Creme", "Iogurte"];

Se decidíssemos alterar todo os sabores para vendê-los como orgânicos, poderiamos escrever o seguinte código:

sorvetes[0] += " orgânico";
sorvetes[1] += " orgânico";
sorvetes[2] += " orgânico";

console.log(sorvetes)[
  ("Chocolate orgânico", "Creme orgânico", "Iogurte orgânico")
];

Mas... e se tivéssemos uma lista com 50 sabores? Faríamos todo esse trabalho manual??? Qual técnica podemos usar para automatizar tarefas para nós?

let sorvetes = ["Chocolate", "Creme", "Iogurte"];

for (let index = 0; index < sorvetes.length; index++) {
  sorvetes[index] += " orgânico";
}

console.log(sorvetes)[
  ("Chocolate orgânico", "Creme orgânico", "Iogurte orgânico")
];

Neste exemplo, a variável index está sendo usada para representar o índice do array.

À medida que index é incrementado, você passa em cada elemento da array, começando de 0 até chegar a sorvetes.length - 1 (sorvete.length está fora do limite).

Conteúdo Extra Aula: Outros métodos de arrays:


Objetos

Objetos são estruturas que nos permitem "embalar" dados e funcionalidades relacionadas e um unico container.

Sabia que arrays também são objetos?

Exemplo de objeto em javascript:

DICA: vale a pena notar que, enquanto podemos representar objetos do mundo real como objetos JavaScript, a analogia nem sempre é válida. É uma boa forma para pensar sobre a estrutura e propósito dos objetos, mas, à medida que você continua sua carreira de desenvolvedor, descobrirá que objetos em JavaScript podem ser comportar de maneira muito diferente dos objetos do mundo real.

NOTA: typeof é um operador que retorna o nome do tipo de dado que o segue:

typeof "hello"; // retorna "string"
typeof true; // retorna "boolean"
typeof [1, 2, 3]; // retorna "object" (Arrays são do tipo bject)
typeof function hello() {}; // retorna "function"

Dados primitivos do javascript

  • strings
  • numbers
  • booleans
  • undefined
  • null

O que é um objeto?

Objetos são estruturas de dados no Javascript que podem armazenar dados de uma determinada coisa e nos ajuda a encontrar esses dados usando o conceito de chave e valor

Exemplo:

let celular = {
  color: "black",
  model: "Samsung S9",
  year: 2019,
  system: "Android",
  isUpToDate: true,
};
let person = {
  name: "Maria",
  age: 25,
  parents: ["Pedro", "Joana"],
  siblings: ["Marta"],
  favoriteColor: "red",
  pets: true,
};

A sintaxe que você vê acima é chamada notação literal de objeto. Há algumas coisas importantes de que você precisa se lembrar quando está estruturando um objeto literal:

A "chave" (representando o nome da propriedade ou método) e seu "valor" são separados de cada um por dois pontos Os pares chave: valor são separados de cada um por vírgulas O objeto inteiro é colocado dentro de chaves { }.

E, assim como você pode procurar por uma palavra no dicionário para encontrar sua definição, a chave em um par chave:valor permite que você busque uma informação sobre um objeto. Aqui estão alguns exemplos de como você pode recuperar informações sobre os pais da minha irmã usando o objeto criado por você.

// duas maneiras equivalentes de usar a chave para retornar seu valor
sister["parents"]; // retorna [ "Pedro", "Joana" ]
sister.parents; // também retorna ["Pedro", "Joana"]

O uso de sister["parents"] é chamado de notação de colchetes (por causa dos colchetes!) e o uso de sister.parents é chamado de notação de ponto (por causa do ponto!).

Métodos

O objeto acima contém um bocado de propriedades sobre uma pessoa, mas não diz realmente o que a pessoa faz. Por exemplo, digamos que a pessoa goste de pintar. Você pode ter um método paintPicture() que retorna "Maria pintou um retrato" toda vez que chamá-lo.

A sintaxe para isso é muito semelhante a como você definiu as propriedades do objeto.

A única diferença é que o valor no par chave:valor será uma função.

let person = {
  name: "Maria",
  age: 25,
  parents: ["Pedro", "Joana"],
  siblings: ["Marta"],
  favoriteColor: "red",
  pets: true,
  paintPicture: function () {
    return "Maria pinta!";
  },
};

person.paintPicture();
// Retorna: "Maria pinta!"

Você também pode ver o nome da pessoa acessando a propriedade name:

person.name;
// Retorna "Maria"

Objetos são uma das mais importantes estruturas de dados em JavaScript. Prepare-se para vê-los em todos os lugares!

Eles possuem propriedades (informações sobre o objeto) e métodos (funções ou capacidades que o objeto tem).

Objetos são um tipo de dado incrivelmente poderoso, e você os verá em todos os lugares quando trabalhar com JavaScript ou qualquer outra linguagem de programação orientada a objetos.

Objetos literais, métodos e propriedades

Você pode definir objetos usando a notação literal de objeto:

let myObject = {
  color: "orange",
  shape: "sphere",
  type: "food",
  eat: function () {
    return "yummy";
  },
};

myObj.eat(); // método
myObj.color; // propriedade

Convenções de nomenclatura

Fique à vontade para usar números e letras maiúsculas ou minúsculas, mas não inicie o nome de sua propriedade com um número. Você não precisa envolver a string com aspas! Se é uma propriedade com mais de uma palavra, use camel case. Não use hífens no nome de suas propriedades

var garfield = {
  "1stCat": true;
  "loves-lasagna": true;
};

garfield.1stSon // error
garfield.loves-lasagna // error